ListView和RecyclerView缓存的区别

ListView

1.继承重写BaseAdapter类

2.自定义ViewHolder与ConvertView的优化

布局

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

缓存机制

两级缓存

mActiveViews:快速重用屏幕上可见的列表项,不需要重新createView和bindView;

mScrapViews:缓存离开屏幕的ItemView,目的是让即将进入屏幕的ItemView重用.

    ListView和RecyclerView缓存的区别_第1张图片

刷新

通常情况下的刷新都是全局刷新(消耗资源) 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(标识状态);

   ListView和RecyclerView缓存的区别_第2张图片

 

刷新:

局部刷新notifyItemChanged

点击事件

只有唯一的API:addOnItemTouchListener();

空数据

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

ListView和RecyclerView缓存机制对比:

1. 层级不同:

RecyclerView比ListView多两级缓存,支持多个离ItemView缓存,支持开发者自定义缓存处理逻辑,支持所有RecyclerView共用同一个RecyclerViewPool(缓存池)。

ListView(两级缓存):

    ListView和RecyclerView缓存的区别_第3张图片

RecyclerView(四级缓存):

    ListView和RecyclerView缓存的区别_第4张图片

ListView和RecyclerView缓存机制基本一致:

1). mActiveViews和mAttachedScrap功能相似,意义在于快速重用屏幕上可见的列表项ItemView,而不需要重新createView和bindView;

2). mScrapView和mCachedViews + mReyclerViewPool功能相似,意义在于缓存离开屏幕的ItemView,目的是让即将进入屏幕的ItemView重用.

3). RecyclerView的优势在于a.mCacheViews的使用,可以做到屏幕外的列表项ItemView进入屏幕内时也无须bindView快速重用;b.mRecyclerPool可以供多个RecyclerView共同使用,在特定场景下,如viewpaper+多个列表页下有优势.客观来说,RecyclerView在特定场景下对ListView的缓存机制做了补强和完善。

2.缓存不同:

1). RecyclerView缓存RecyclerView.ViewHolder,抽象可理解为:

View + ViewHolder(避免每次createView时调用findViewById) + flag(标识状态);

2). ListView缓存View。

RecyclerView中mCacheViews(屏幕外)获取缓存时,是通过匹配pos获取目标位置的缓存,这样做的好处是,当数据源数据不变的情况下,无须重新bindView:

而同样是离屏缓存,ListView从mScrapViews根据pos获取相应的缓存,但是并没有直接使用,而是重新getView(即必定会重新bindView)

 

你可能感兴趣的:(Android,ListView,RecyclerView)