转载https://juejin.cn/post/6844903942573260814https://juejin.cn/post/6844903942573260814
大体的思路:
- 把cell中的子控件布局改成frame的相对布局,禁止采用自动布局或者约束;
- 在接收到IM下发的消息时,提前计算好当前数据所需要的布局样式,内容需要占多宽多高、用户昵称的颜色、内容的字体样式、对应cell需要的高度,等等相关的属性值都提前计算好,并缓存起来;
- 在有新数据添加到表格中,采用insert方式,不要采用reload;
- 数据不是下发一条就添加一条道表格中,而是采用定时器,定时1秒去处理;
- 采用两个缓存池,一个是用于维护表格当前数据所存储的池,暂时叫B池;另一个用于接收处理好的IM数据缓存池,暂时叫A池;
- 表格数据缓存B池容量确定为300条数据,当数据到达300条时,清空150条;也就是说缓存池中最少150条,最多300条(数量可以自己定,最多不要超过500条);
定时器
- 作用是:每隔一秒去 A缓存池 中取数据放到 B缓存池;
- 如果A缓存池中没有数据则把自己(定时器)休眠;
- 当把A缓存池中的数据复制到B缓存池中,清空A缓存池数据。
A缓存池
- 当有新IM数据过来时,把处理好的数据存入到A缓存池中。
- 判断定时器是否在运作,如果不在运作则唤醒定时器,如果在运作则直接返回;
B缓存池
- 监听B缓存池中的数据的变化;
- 判断加入新数据后,缓存池的数据总数是否会超过最多数据量;
- 如果会超过,则删除指定数量的历史数据;
- 把对应新增的数据插入到表格对应的位置;