Android 布局异步加载中的pools对象缓存池源码分析

boolean release(@NonNull T instance);

}

SimplePool的源码

具体的实现逻辑在SimplePool,但这里没有加锁,如需要加锁,使用SynchronizedPool即可。 缓存大小mPoolSize必须大于0,否则抛出异常。 调用acquire()时候,先判断mPoolSize是否大于0: 如果小于0,返回null。 如果大于0,证明对象池中还有可用对象,然后取一个使用,这个对象从数组中移出(后面release会把它再加回来,觉得这里设计好巧妙)。mPoolSize减一。返回缓存实例。

调用release(),会先调用isInPool()判断这个对象是否存在数组中,存在就抛出异常。因为acquire()时候已经把它移出了。主要防止一个对象重复保存到数组中,操作同一对象发生未知异常。 然后判断pool是否已满,如果没有存满,缓存一个对象,mPoolSize加一。如果存满,直接返回false。下面是SimplePool的源码。

public static class SimplePool implements Pool {

//线程池对象数组

private final Object[] mPool;

//线程池目前可用对象size,意思是还存在多少个对象在数组中。

private int mPoolSize;

/**

  • Creates a new instance.

  • 最大对象池size

  • @param maxPoolSize The max pool size.

  • @throws IllegalArgumentException If the max pool size is less than zero.

*/

public SimplePool(int maxPoolSize) {

if (maxPoolSize <= 0) {

throw new IllegalArgumentException(“The max pool size must be > 0”);

}

mPool = new Object[maxPoolSize];

}

public T acquire() {

//判断 mPoolSize ,判断对象池是否已经用完了。用完了返回null

if (mPoolSize > 0) {

//取一个下标

final int lastPooledIndex = mPoolSize - 1;

//取出一个对象

T instance = (T) mPool[lastPooledIndex];

//把这个对象从数组中移出(后面release会把它再加回来)觉得这里设计好巧妙。

mPool[lastPooledIndex] = null;

//下标减1,意思是已经拿走一个去使用了。

mPoolSize–;

//返回对象

return instance;

}

//对象池用完了,返回null,让上层自己去新建一个吧

return null;

}

@Override

public boolean release(@NonNull T instance) {

//主要防止一个对象重复保存到数组中,判断这个对象是否存在数组中,存在就抛出异常。

//因为acquire()时候已经把它移出了。

if (isInPool(instance)) {

throw new IllegalStateException(“Already in the pool!”);

}

//如果没有存满,缓存一个对象。

if (mPoolSize < mPool.length) {

//把上面从数组中移出对象,再次保存回来。(移出保存是同一个哦)毕竟不是一次性的。

mPool[mPoolSize] = instance;

//池子大小加一

mPoolSize++;

return true;

}

//存满了,返回false ,这个上层可以针对这个做对应逻辑。

return false;

}

private boolean isInPool(@NonNull T instance) {

//查找这个对象是否存在数组中

for (int i = 0; i < mPoolSize; i++) {

if (mPool[i] == instance) {

return true;

}

}

return false;

}

}

如果需要同步

使用SynchronizedPool即可。

来让我们看看大致的流程图

流程图,丑是丑了点,将就看看吧!

想要深入了解更多Android进阶知识与资料可以叫入粉丝交流群:872206502

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

资源分享

一线互联网面试专题

379页的Android进阶知识大全

379页的Android进阶知识大全

点击:

**《Android架构视频+BAT面试专题PDF+学习笔记​》**即可免费获取

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

561972)]

点击:

**《Android架构视频+BAT面试专题PDF+学习笔记​》**即可免费获取

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

2020年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。祝大家2021年万事大吉。

  • 24
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值