Q.1:引用計數(shù)到底是在指針上還是在實(shí)際對象內(nèi)存中
Q.2:Effective Objc里面提到的被strong修飾的屬性在設(shè)置新值得時候會保留新值釋放舊值是什么意思
Q.3:調(diào)用set方法賦值和不調(diào)用set方法賦值對引用計數(shù)有什么影響
Q.4:為什么有時候引用計數(shù)為0后,依然可以正常調(diào)用該對象的變量和方法
由于ARC不允許直接調(diào)用retainCount和retain,release方法所以使用運(yùn)行時的庫進(jìn)行研究
#import <objc/runtime.h>
//.h文件中定義屬性
@property(nonatomic,strong) objectA *a;
Q.1比較好解釋清钥,在.m文件中不對a初始化查看引用計數(shù)會崩潰琼锋,而初始化之后就不會了,可以很明顯的得出引用計數(shù)是針對指針?biāo)赶虻膶ο蟮亩皇侵羔槺旧?/p>
Q.2
NSLog(@"%ld", CFGetRetainCount((CFTypeRef)_a));
//.m文件中定義
NSObject *b = [[objectA alloc] init];
CFRetain((__bridge CFTypeRef)(b));
CFRetain((__bridge CFTypeRef)(b));
CFRetain((__bridge CFTypeRef)(b));//b:RefCt = 4
NSObject *c = [[objectA alloc] init];//c:RefCt = 1
_a = c;//先不調(diào)用set方法避免干擾
/*
以上代碼輸出后引用計數(shù)輸出為
a:RefCt = 2,b:RecCt = 2
a和b引用計數(shù)均+1
*/
_a = b;
/*
以上代碼輸出后引用計數(shù)輸出為
a:RefCt = 5,b:RecCt = 5,c:RefCt = 1
a引用計數(shù)變5,b引用計數(shù)+1,c引用計數(shù)-1
*/
綜上:可以得出strong關(guān)鍵字修飾的屬性在設(shè)置新值的時候流程是先把將要賦給該指針的值引用計數(shù)+1祟昭,然后讓改指針原本所指向的內(nèi)存引用計數(shù)-1缕坎,又因?yàn)橐糜嫈?shù)是針對實(shí)際對象的而不是針對指針的Q.1的結(jié)論,故將該指針指向新值指針?biāo)诘膬?nèi)存的時候篡悟,引用計數(shù)直接變成新值得引用計數(shù)谜叹,
的保留新值和釋放舊值不如說翻譯成[新值 retain],[舊值 release]比較好
Q3.這個問題我也還沒有具體搞清楚,只知道使用self.object打印引用計數(shù)的時候會比_obejct多1搬葬,但是打印過后引用計數(shù)又會恢復(fù)原樣荷腊,可能是self多引用了一次?
Q.4我糾結(jié)了好久,在MRC研究引用計數(shù)的的時候經(jīng)常出現(xiàn)這種情況,不管是release之后引用計數(shù)變0還是直接dealloc掉一個對象都有能繼續(xù)正常操作該對象的現(xiàn)象
最后答案其實(shí)是
如果調(diào)用release后急凰,基于某些原因女仰,引用計數(shù)降至0,那么number對象所占內(nèi)存也許會被回收,這樣的話再調(diào)用NSLog可能會使程序崩潰疾忍,筆者在這里只說可能乔外,而沒說一定,因?yàn)閷ο笏嫉膬?nèi)存在‘接觸分配’后一罩,只是返回可用內(nèi)存池杨幼,如果執(zhí)行l(wèi)og時尚未復(fù)寫對象內(nèi)存,那么該對象依然有效聂渊,這是程序不會崩潰
該答案來自effective objective-c 2.0