ListView

1.继承重写BaseAdapter类
2.自定义ViewHolder与ConvertView的优化

布局

单一布局,只可以实现纵向效果

缓存机制

两级缓存
mActiveViews:快速重用屏幕上可见的列表项,不需要重新createView和bindView;
mScrapViews:缓存离开屏幕的ItemView,目的是让即将进入屏幕的ItemView重用.
Android之ListView,RecyclerView

刷新

通常情况下的刷新都是全局刷新(消耗资源) notifyDataSetChanged()
局部刷新步骤:①实现onItemChanged()方法
       ②通过onItemChanged()方法获取对应的position
       ③通过getView()实现局部的刷新

点击事件

ListView实际是自带点击事件的,可以直接调用API:onItemClickListener();onItemLongListener();onSelecterListener()
方法二:
①通过getItemId()返回的id对用Item(此处不可以通过position,因为一旦有头部和底部会出现越界的问题,在此处不建议使用)
②在Adapter中针对,每一个item写在getView()方法中

空数据

具有处理空数据的方法setEmptyView()

RecyclerView

布局

不光可以实现纵向布局,还可以实现横向,表格,瀑布流等布局。

缓存机制

四级缓存机制:支持多个离ItemView缓存,支持开发者自定义缓存处理逻辑,支持所有RecyclerView共用同一个RecyclerViewPool(缓存池)。
mAttachedScrap:快速重用屏幕上可见的列表项,不需要重新createView和bindView;与ListView的mActiveViews作用一致。
CachedViews + mReyclerViewPool:缓存离开屏幕的ItemView,目的是让即将进入屏幕的ItemView重用与mScrapViews功能一致。
mRecyclerPool可以供多个RecyclerView共同使用,在特定场景下,如viewpaper+多个列表页下有优势
mViewCacheExtension:需要用户定制,默认情况下不实现,自定义获取holder缓存
缓存:
View + ViewHolder(避免每次createView时调用findViewById) + flag(标识状态);
Android之ListView,RecyclerView

刷新

局部刷新notifyItemChanged

点击事件

只有唯一的API:addOnItemTouchListener();

空数据

不含有处理空数据的方法,需要自己进行数据空的判断

总结

通过上边对LiatView和RecyclerView对比,我们可以发现Recycler和List相比较而言,由于两者的缓存机制的不同,所以只有在列表页展示界面,需要支持动画,或者频繁更新,局部刷新的情况下,RecyclerView的有时会很明显,显得强大完善,易扩展;在其余的情况下,ListView还是可以满足用户需求的,而且更加的方便使用而且快捷。

相关文章: