2 回答

TA貢獻1844條經驗 獲得超8個贊
如兩個對象NSString *str1=[[NSString alloc] initWithString:@"string1"];
NSString *str2=[[NSString alloc] initWithString:@"string2"];
str2=str1; //使指針str2的指向與str1指向相同內存。結果就是造成了上面的alloc下動態分配
的內存,內存泄露.當調用[str1 release]; [str2 release];內存的釋放最終調用的是[str1 dealloc];
或者是[str2 dealloc],什么情況下才會調用這個釋放內存的dealloc方法呢?當創建的對象其引用計數(retainCount)為0時,就會調用。
而哪些方法會造成引用計數改變呢?
1.調用alloc方法
2.調用copy,retain 特性
3.relase方法
str2=[str1 copy]; 引用計數加1,所以當調用[str1 release];時str2與str1指向的共同對象并未析構,就是還存在。如果用直接復制str2=str1就不存在了。
引用計數變化為: 1.調用alloc使引用計數加1,變為了1.
2.調用copy,引用計數加1,變為2.
3.調用release,引用計數減1,變為1; 所以引用計數不為0,不會調用dealloc釋放內存
的函數,所以內存還存在,如果要釋放內存,必須再release一次。
所以這才是兩者之間根本區別。
用C語言解釋就是,新分配一塊內存空間來存儲要復制的值。
- 2 回答
- 0 關注
- 701 瀏覽
添加回答
舉報