ListView和RecyclerView原理简析
照例,首先贴出本文档所记课程的网址:http://coding.imooc.com/learn/list/100.html
1、ListView原理简析
RecyclerView是ListView的替代者,为了弄清楚RecyclerView的工作原理,先弄清楚较为简单的ListView的工作原理很有必要。
1.1、适配器模式
所谓适配器模式是把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作。对于ListView和RecyclerView来说,其主要使用的是对象适配器模式(通过组合方式实现),对象适配器模式类图如下:
对象适配器模式类图从图中可以看出,所谓适配器模式,就是适配器(Adapter)将被适配者(Adaptee)转为为客户所需要的目的接口(Target)。比如,有一个220V的电压输入,为了给一个电压为5V的手机充电,那么必须通过一个适配器将这220V的电压转换为5V才可以供用户使用。
适配器模式的使用场景:通常应用于进行不兼容的类型转换的场景。
1.2、ListView适配器模式
ListView并不操作单个视图和数据,这是因为,ListView会面对各种各样的数据和View,因此,ListView将每个Item的View抽离出来,由Adapter去填充数据和视图,然后再由ListView调用。在这个过程中,需要显示的数据集合和ItemView就是Adaptee,ListView就是Client,所有Adapter都实现了BaseAdapter(Target)接口。
可以这样说,Adapter是实现了视图与数据分离的桥梁,其功能是将数据绘制到相对应的item上。
1.3、ListView的recyclerBin机制
ListView中管理的元素是View,ListView管理每个由Adapter返回的View,并将之加入RecyclerBin机制中,以此可以得以复用已加载过的View,以提高效率。其逻辑如下图:
recyclerBin复用View逻辑图1.4、ListView的优化
为了重用convertView,使用ViewHolder。这个属于经验写法。此处不赘。
2、RecyclerView原理简析
RecyclerView和ListView一样,也是通过Adapter将视图和数据分离出来。由RecyclerView管理每个元素,但在这里的元素,不是ListView中的View,而是ViewHolder。因此RecyclerView与一下几个类有关。
2.1、ViewHolder
RecyclerView里面管理的元素已经不是View而是ViewHolder了,因此,Android规定我们的具体ViewHolder必须继承给定ViewHolder抽象类。每个ViewHolder保存相应的视图和数据,并自己显示。
2.2、RecyclerView.Adapter
这是适配器模式中的Target,我们必须定义具体的Adapter继承之。类似于ListView中Adapter需要返回相应的View一样,此处也需要返回相应的ViewHolder,具体的ViewHolder类型通过泛型的方式注入到Adapter中。Adapter中有几个关键的方法:
1、getItemCount()
返回Item的数量,通过数据集合的个数获得。以此确定Viewholder的数量。
2、getItemViewType(int position)
通过Item的位置确定该位置的ViewHolder的类型,以此区分不同的Item。
3、onCreateViewHolder()
根据相应的ViewType创建相应的视图,并将该视图绑定到一个新的ViewHolder并返回。
4、onBindViewHolder()
该方法里面,主要是将数据绑定到对应的ViewHolder上。onCreateViewHolder()方法和该方法类似于ListView中的getView()。
2.3、LayoutManager
RecyclerView并不像ListView规定里面的Item只能以某种方式布局,RecyclerView可以将里面的Item以各种各样的方式放置,这是通过LayoutManager做到的。不同的LayoutManager可以使ViewHolder以不同的方式呈现。比如LinearLayoutManager使之呈线性,而GridLayoutManager使之呈网格,我们也可以定义自己的LayoutManager。
2.4、缓存与复用
RecyclerView也有它自己的复用机制,是通过多加载几个ViewHolder以备用,而划出去的ViewHolder则放入复用池中。这对于使用RecyclerView来说并非重点,此处不赘。