场景
项目需要在私聊中来实现一个阅后即焚的功能,即 A 用户给 B 用户发送消息,B 用户在进入聊天页面查看之后 A 用户删除此消息,B 用户开始进入倒计时,倒计时结束后,删除此消息。
思考
大体的梳理一下具体的逻辑
- A -> B
- B 进入会话页面
- B 将此消息开始倒计时
- 通知 A 我已进行阅读
- A 删除消息
从上面内容我们来大体的设计一下我们需要用户的技术
- 单例类
- 自定义消息,用来告诉 A 我已经开始阅读了,你删除吧
- 一个用于维护阅后即焚消息的管理类
- 一个存储 A 给 B 发送的所有的阅后即焚的消息的容器 A <k, v> k 为 targetid ,v 为 messageIDs
- 一个存储每条阅后即焚消息的容器 B <k,v> k 为 messageId, v 为当前消息还剩的倒计时时间。
- 一个用来存储所有阅后即焚消息的容器 C K:ID V:msg
- 两个处理队列 一个处理时间 一个处理消息
对外暴露接口
- 代理 接收方焚烧消息的每秒倒计时
- 通知 接收方收到对方已阅读某条消息的通知
详解
- 初始化我们的所有容器
- 收到消息,在合适的业务时机将此消息加入到焚烧队列
- 查询消息是否已经在焚烧队列
- 如果不在,添加到 A B C容器
- 执行倒计时
倒计时操作
- 遍历 C 是否有消息
- 给发送方发送消息,通知我已经开始焚烧 A 里的消息了 并在 A 容器删除此会话
- 发送方收到消息发送通知
- 接收方遍历 B 容器,判断每条消息是否到时
- 如果消息焚烧时间到 在 A、B 容器删除,并触发代理
- 如果没到时间,就触发代理并修改 此消息在 B 容器的时长。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。