转载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条(数量可以自