引子
在面试别人的时候,经常问到weak和assign的区别。然后再深入一点就会问weak是怎么将对象置为nil的。
一般回答到内部维护着一个weak表就算勉强可以了。
但上次面试被阿里问到相同的问题:我自己的回答被嫌弃太过简单。
我的回答是:
Runtime维护了一个Weak表,用于存储指向某个对象的所有Weak指针。Weak表其实是一个哈希表,Key是所指对象的地址,Value是Weak指针的地址(这个地址的值是所指对象的地址)的数组。
在对象被回收的时候,经过层层调用,会最终触发下面的方法将所有Weak指针的值设为nil。
仔细一想确实,至于Weak指针如何注册到Weak表中、如何维护。Hash表的增删改查又是怎么做的?
回来打算仔细探讨一下Weak指针如何注册到Weak表中,又具体是如何释放的?
weak 的实现原理可以概括一下三步:
1、初始化时:runtime会调用objc_initWeak函数,初始化一个新的weak指针指向对象的地址。
2、添加引用时:objc_initWeak函数会调用 objc_storeWeak() 函数, objc_storeWeak() 的作用是更新指针指向,创建对应的弱引用表。
3、释放时,调用clearDeallocating函数。clearDeallocating函数首先根据对象地址获取所有weak指针地址的数组,然后遍历这个数组把其中的数据设为nil,最后把这个entry从weak表中删除,最后清理对象的记录。
再过具体的过程以后再完善。太过复杂。
源码解读