RecyclerView-的复用机制

本文详细解析了RecyclerView的四级缓存机制:mAttachedScrap, mChangedScrap, mCachedViews和RecycledViewPool。复用机制主要在tryGetViewHolderForPositionByDeadline方法中实现,而缓存过程涉及Adapter的notifyXXX方法和LayoutManager的onLayoutChildren方法。通过理解这些,有助于优化RecyclerView的性能和减少内存消耗。" 78823094,7395239,使用Python创建MSI安装包,"['Python开发', '软件打包', 'Windows安装器']
摘要由CSDN通过智能技术生成

}

这些缓存集合可以分为 4 个级别,按优先级从高到底为:

  • 一级缓存:mAttachedScrap 和 mChangedScrap ,用来缓存还在屏幕内的 ViewHolder
  1. mAttachedScrap 存储的是当前还在屏幕中的 ViewHolder;按照 id 和 position 来查找 ViewHolder

  2. mChangedScrap 表示数据已经改变的 ViewHolder 列表, 存储 notifyXXX 方法时需要改变的 ViewHolder

  • 二级缓存:mCachedViews ,用来缓存移除屏幕之外的 ViewHolder,默认情况下缓存容量是 2,可以通过 setViewCacheSize 方法来改变缓存的容量大小。如果 mCachedViews 的容量已满,则会根据 FIFO 的规则移除旧 ViewHolder

  • 三级缓存:ViewCacheExtension ,开发给用户的自定义扩展缓存,需要用户自己管理 View 的创建和缓存。个人感觉这个拓展脱离了 Adapter.createViewHolder 使用的话会造成 View 创建和数据绑定和其它代码太分散,不利于维护,使用场景很少仅做了解

/*

  • Note that, Recycler never sends Views to this method to be cached. It is developers

  • responsibility to decide whether they want to keep their Views in this custom cache or let

  • the default recycling policy handle it.
    */
    public abstract static class ViewCacheExtension {
    public abstract View getViewForPositionAndType(…);
    }

  • 四级缓存:RecycledViewPool ,ViewHolder 缓存池,在有限的 mCachedViews 中如果存不下新的 ViewHolder 时,就会把 ViewHolder 存入 RecyclerViewPool 中。

  • 按照 Type 来查找 ViewHolder

  • 每个 Type 默认最多缓存 5 个

  • 可以多个 RecyclerView 共享 RecycledViewPool

接下来我们看下这四级缓存是怎么工作的

复用

RecyclerView 作为一个 “平平无奇” 的 View,子 View 的排列和布局当然是从 onLayout 入手了,调用链:

RecyclerView.onLayout(…)
-> RecyclerView.dispatchLayout()
-> RecyclerView.dispatchLayoutStep2() // do the actual la

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值