IOS 常見的循環(huán)引用總結(jié)
IOS 常見的循環(huán)引用總結(jié)
介紹:
循環(huán)引用,指的是多個對象相互引用時,使得引用形成一個環(huán)形,導(dǎo)致外部無法真正是否掉這塊環(huán)形內(nèi)存。其實有點類似死鎖。
舉個例子:A->B->C->....->X->B ->表示強引用,這樣的B的引用計數(shù)就是2,假如A被系統(tǒng)釋放了,理論上A會自動減小A所引用的資源,就是B,那么這時候B的引用計數(shù)就變成了1,所有B無法被釋放,然而A已經(jīng)被釋放了,所有B的內(nèi)存部分就肯定無法再釋放再重新利用這部分內(nèi)存空間了,導(dǎo)致內(nèi)存泄漏。
情況一:delegate
Delegate是ios中開發(fā)中最常遇到的循環(huán)引用,一般在聲明delegate的時候都要使用弱引用weak或者assign
@property (nonatomic, weak, nullable) id <UITableViewDelegate> delegate;
當(dāng)然怎么選擇使用assign還是weak,MRC的話只能用assign,在ARC的情況下最好使用weak,因為weak修飾的變量在是否后自動為指向nil,防止不安全的野指針存在
情況二:Block
Block也是比較常見的循環(huán)引用問題,在Block中使用了self容易出現(xiàn)循環(huán)引用,因此很多人在使用block的時候,加入里面有用到self的操作都會聲明一個__weak來修飾self。其實便不是這樣的,不是所有使用了Block都會出現(xiàn)Self循環(huán)引用問題,只有self擁有Block的強引用才會出現(xiàn)這種情況。
所以一般在函數(shù)中臨時使用Block是不會出現(xiàn)循環(huán)應(yīng)用的,因為這時候Block引用是屬于棧的。當(dāng)棧上的block釋放后,block中對self的引用計數(shù)也會減掉
當(dāng)然不一定要Self對Block有直接的引用才會出現(xiàn),假如self的變量B,B中有個Block變量,就容易出現(xiàn)這種情況,好的是在block出現(xiàn)循環(huán)引用的,xcode7會出現(xiàn)警告提示(之前版本不確定)。
情況三:NSTimer
這是一個神奇的NSTimer,當(dāng)你創(chuàng)建使用NSTimer的時候,NSTimer會默認對當(dāng)前self有個強引用,所有在self使用完成打算是否的時候,一定要先使用NSTimer的invalidate來停止是否時間控制對self的引用
[_timer invalidate];
總結(jié):
上面說的是我們常見的,其實循環(huán)引用就是說我們的強引用形成了閉環(huán),還會有很多自己寫的代碼中會出現(xiàn),平時還是要注意寫法。當(dāng)然xcode的instruments也能幫助到大家排除一些這樣類似的內(nèi)存問題。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
iOS 鍵盤輸入限制(只能輸入字母,數(shù)字,禁止輸入特殊符號)
本文主要介紹了iOS中鍵盤輸入限制(只能輸入字母,數(shù)字,禁止輸入特殊符號)的方法。具有很好的參考價值。下面跟著小編一起來看下吧2017-04-04
Xcode 下刪除Provisioning Profiles文件詳細介紹
這篇文章主要介紹了Xcode 下刪除Provisioning Profiles文件詳細介紹的相關(guān)資料,需要的朋友可以參考下2016-12-12
iOS給圖片添加濾鏡&使用openGLES動態(tài)渲染圖片詳解及實例
這篇文章主要介紹了iOS給圖片添加濾鏡&使用openGLES動態(tài)渲染圖片詳解及實例的相關(guān)資料,需要的朋友可以參考下2016-10-10
深入講解iOS開發(fā)中應(yīng)用數(shù)據(jù)的存儲方式
這篇文章主要介紹了iOS開發(fā)中應(yīng)用數(shù)據(jù)的存儲方式,包括plistXML屬性列表和NSKeydeArchiver歸檔兩個部分,需要的朋友可以參考下2015-12-12

