远程教学之消息顺序保证机制.md
1.75 KB
以IOS目前的实现思路为例说明
针对页面内的动作消息进行同步处理,包括按钮的点击,手势操作以及播放器的播放等
发送方记录的同步信息:
- 学习页的编号(从0开始递增,每次进入学习页,本次学习的总学习页编号加1)
- 页内动作的编号(从0开始递增,在学习内内,每做一个动作,该页的动作编号加1,在进入新的学习页后重置为0)
接收方的同步信息
- 期待的学习页的编号(从0开始,每次收到新的符合顺序的学习页信息,本编号加1)
- 期待的页内动作的编号(从0开始,每次收到信的符合顺序的页内动作信息,本编号加1)
同步策略
- 消息接收端构造1个本地缓存消息队列
- 发送端有变量记录发送的学习也序号和页内消息序号,接收端有变量记录期待收到的学习页的序号,和消息序号
- 当收到的消息符合不符合期待序号的时候(例如后发先至的消息),把该消息缓存到队列
- 当收到的消息符合期待序号的时候,直接处理该消息,更新期待的消息序号,处理完消息后检查缓存队列中是否有期待的消息序号,如果有则拿出来继续处理,重复执行本条逻辑直到缓存队列中没有期待的消息序号为止。
- 当接收端创建一个新的学习页面后,要从队列中查看是否有先于页面到达的页内动作信息,有则处理,没有则等待动作消息到达。
- 切换页面的时候,重置期待页内消息序号,清空队列中之前页面的动作消息。
- 结束课程的时候,重置期待学习页序号,页内消息序号,清空队列。