RecyclerView中的notifyItemInserted和notifyItemRemoved方法的使用

本文分享了在使用RecyclerView时,如何正确地使用notifyItemInserted和notifyItemRemoved方法避免IndexOutOfBoundsException异常,确保在添加或删除item时的稳定性。文章强调了使用getItemCount()和getLayoutPosition()方法来准确计算item位置的重要性。
摘要由CSDN通过智能技术生成

使用notifyItemInserted方法向末尾处添加item的时候,要使用如下的方式

notifyItemInserted(getItemCount());

其中getItemCount()才能正确的计算出插入的位置,然后在调用

notifyItemChanged(getItemCount());

方法更新一下即可

如果使用list.size()-1计算插入位置的话,一个一个的插入也没什么问题,但是快速连续插入的话就会报出IndexOutOfBoundExcetion的异常,导致崩溃

 

使用 notifyItemRemoved方法删除时,需要使用getLayoutPosition计算位置

否则也会报出IndexOutOfBoundExcetion异常,同时使用

notifyItemChanged(removePos);方法刷新一下

工作中遇到的问题,mark一下

RecyclerView嵌套RecyclerView的情况下,如果在内部RecyclerView进行数据更新时调用notifyDataSetChanged方法,可能会导致UI卡顿。这是因为notifyDataSetChanged方法会通知适配器重新绑定所有数据,如果数据集很大或者操作频繁,就会导致性能问题。以下是一些解决方案: 1. **局部刷新**:避免使用notifyDataSetChanged,而是使用更精细的方法来通知适配器数据的变更,比如通过调用notifyItemInsertednotifyItemRemoved或者notifyItemChanged方法,只刷新变化的部分。 2. **使用DiffUtil**:利用DiffUtil类来计算数据变更的差异,它可以更高效地比较旧数据集和新数据集之间的差异,并且只更新变化的部分。DiffUtil提供了计算差异的机制,并且可以通过RecyclerView的AsyncListDiffer类在后台线程上执行这些计算,从而减少主线程的压力。 3. **优化数据结构和适配器逻辑**:对于复杂的嵌套RecyclerView结构,优化数据结构和适配器逻辑可以减少不必要的数据处理和视图重绘。比如,确保在适配器不要做复杂的计算,避免在onBindViewHolder方法进行昂贵的操作。 4. **减少嵌套RecyclerView的层数**:在可能的情况下,尝试减少嵌套RecyclerView的层数。嵌套层数越多,性能影响越严重。考虑是否可以使用其他布局结构来替代。 5. **异步加载和渲染优化**:对于大量的数据处理,应该在后台线程进行,避免阻塞主线程。此外,可以适当减少内部RecyclerViewitem数量,通过分页或滚动加载来提高性能。 6. **使用RecyclerView的缓存机制**:正确利用RecyclerView的缓存机制可以提高滚动性能。在自定义的RecyclerView的子类,可以通过覆写相关方法来调整缓存大小和策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值