- alloc
alloc 经过一系列调用最终调用的c函数中的calloc方法,在alloc对象时,引用计数并没有加1.那为什么在使用retainCount获取时,引用计数+1 了呢??
2.retain
retain实现流程在使用retain时,系统是怎样查找引用计数的??
两个Hash查找,
第一次查找到:在那一张sideTable 表中,
对象指针通过相应的Hash函数获取到相应的存储ke y,即在SideTables 的索引位置。从而获取到相应的SideTable 表。
第二次:查找到:在sideTable 表中的具体位置。
通过当前变量的引用计数指针到SideTable 中,获取引用计数Map.即它的引用计数size_t.然后进行加1操作,所谓的+1,其实是偏移量。
- release的相关实现原理
- retainCount 实现原理
首先查找到对应的SideTale ,然后,声明一个变量
size_t refcnt_result = 1;
最后到SideTable中查找,找到对应的你用计数size_t ,再进行偏移,偏移后的值,在与refcnt_result 进行+= 操作。 由于新alloc的对象没有key-value的映射的,所以获取到的值是0.经过retainCount 的中的+= 操作,最后成为了1.
5.dealloc 的实现原理
开始--> 首先会调用_objc_rootDealloc()的私有函数-->私有函数中,又会调用rootDealloc 函数--> 然后在其内部,会判断,当前对象是否可以直接释放
释放的判断条件:
(1)nonpointer_isa 是否使用了非指针型isa.
(2)是否有弱引用关系
(3)是否有关联对象
(4)是否有c++或ARC相关代码
(5)是否有挂载的散列表
全都没有的情况下,可以直接调用c函数的free进行释放,否则需要调用objc_dispose()函数,清除所有关系后,再进行释放的操作。
流程图objc_dispose 的内部实现??
首先会调用objc_destructInstance(),在这个方法中,首先判断是否有c++或者ARC相关内容,如果说存在就去调用objc_cxxDestruct()销毁,如果说没有,就会判断是否存在关联对象,如果存在关联对象的话,就去调用_object_reomve_assocations() 方法进行移除,如果说没有,系统会调用clearDeallocating()函数,在该函数中,首先调用了一个sideTable_clearDeallcating()函数,之后回到用weak_clear_no_lock()函数,该函数是将指向该对象的弱引用指针置为 nil 这个方法过后,会调用table.refcnts.erase()引用计数擦出即从引用计数表中,将该对象的引用计数擦出。.然后再调用C函数free结束实现。
dispose流程
网友评论