實(shí)際開(kāi)發(fā)中-Block導(dǎo)致循環(huán)引用的問(wèn)題

說(shuō)到循環(huán)引用問(wèn)題,最最最常遇到的,不是在項(xiàng)目中棒口,而是在面試中。如果面試官問(wèn)你開(kāi)發(fā)中是否遇到過(guò)retain cycle焰情,你如果說(shuō)沒(méi)遇到過(guò)陌凳,估計(jì)已經(jīng)很難跟面試官繼續(xù)友好的溝通下去了。

但是這個(gè)問(wèn)題怎么回答呢内舟,網(wǎng)絡(luò)上千篇一律的答案-->使用Block的時(shí)候遇到過(guò)合敦,使用__weakSelf 代替 self 等等,可以說(shuō)這個(gè)答案沒(méi)啥錯(cuò)验游,但是所有人都回答的一樣充岛,并不能突出我們的逼格,無(wú)法讓面試官知道我們?cè)谶@方面有過(guò)研究耕蝉,有閃光點(diǎn)崔梗。

對(duì)于開(kāi)發(fā)者來(lái)說(shuō),喜歡探索垒在,喜歡挖掘不懂的知識(shí)蒜魄,在面試官眼里會(huì)加分不少。探索是基于問(wèn)題之上的-->比如:是否所有的Block中,使用self 都會(huì)導(dǎo)致循環(huán)引用谈为?


系統(tǒng)自帶Block不會(huì)發(fā)生循環(huán)引用

如圖旅挤,使用系統(tǒng)自帶的UIView 的Blcok,控制器能被銷毀-->說(shuō)明沒(méi)有發(fā)送循環(huán)引用伞鲫。

原理: UIView的調(diào)用的是類方法粘茄,當(dāng)前控制器不可能強(qiáng)引用一個(gè)類 ,所以循環(huán)無(wú)法形成 --> 動(dòng)畫(huà)block不會(huì)造成循環(huán)引用的原因秕脓。


所以通過(guò)實(shí)踐得出第一個(gè)結(jié)論--> 并不是所有的Block中使用self柒瓣,都會(huì)導(dǎo)致循環(huán)引用!


問(wèn)題二:面試官問(wèn):那除了系統(tǒng)自帶的方法中的Block吠架,你在其他Block中使用self 會(huì)導(dǎo)致循環(huán)引用嗎芙贫? -->可答:AFN框架!

最常用的數(shù)據(jù)請(qǐng)求框架-- AFNetWorking框架的Block是否會(huì)強(qiáng)引用傍药?

AFN的Block是否會(huì)導(dǎo)致循環(huán)引用測(cè)試

如上圖所示屹培,在AFN的 block { xxx self.view ?} 使用self,并不會(huì)導(dǎo)致循環(huán)引用怔檩!

原理:AFN無(wú)循環(huán)是因?yàn)榻^大部分情況下褪秀,你的網(wǎng)絡(luò)類對(duì)象是不會(huì)被當(dāng)前控制器引用的,這時(shí)就不會(huì)形成引用環(huán)薛训。(查閱資料得知)

小tips:也可能AFN底層有自己做了操作媒吗,這里沒(méi)探究到AFN框架底層,僅知道AFN不會(huì)造成循環(huán)引用乙埃。


那什么情況下會(huì)導(dǎo)致循環(huán)引用呢闸英? --> 自定義Block

自定義Block中使用self

添加 viewDidLoad 提示框-->每次進(jìn)入都打印viewDidLoad,可以確定是否離開(kāi)視圖控制器-->如果是介袜,但是沒(méi)有調(diào)用dealloc --> 循環(huán)引用

循環(huán)引用

這時(shí)候甫何,我們發(fā)現(xiàn)循環(huán)引用發(fā)生了!所有我們答道:“我們?cè)趯?shí)際開(kāi)發(fā)中遇伞,使用自定義Block辙喂,在Block { xxx }中使用self,導(dǎo)致了循環(huán)引用 ”

循環(huán)引用導(dǎo)致的原因: 相互強(qiáng)指向

循環(huán)引用原因

如何解決-->使用weakSelf鸠珠,這個(gè)解決方法估計(jì)沒(méi)見(jiàn)過(guò)一百次的巍耗,都不算是真正參加過(guò)iOS面試的。

----------------------------- 華麗分割線--------------------------------------

一個(gè)大寫(xiě)的excuse me 寫(xiě)臉上渐排,49行都報(bào)警告了炬太,而且提示可能發(fā)送循環(huán)引用,這你都能因?yàn)檫@樣導(dǎo)致循環(huán)引用驯耻?亲族?這面試官如果知道這個(gè)炒考,應(yīng)該不會(huì)這么友好的放過(guò)你吧?


由于現(xiàn)在學(xué)iOS的太多了霎迫,所有可能面試官如果對(duì)于循環(huán)引用比較了解的話票腰,并不會(huì)因?yàn)槲覀兓卮鹆松厦鎯蓚€(gè)問(wèn)題就放過(guò)我們~他可能會(huì)接著問(wèn):那如果是我們自己寫(xiě)的Block,(非系統(tǒng)和AFN)女气,在Block中使用self,是否一定會(huì)發(fā)生循環(huán)引用~


探究四:自定義Block是否一定會(huì)發(fā)生循環(huán)引用测柠?

在其他控制器聲明一個(gè)強(qiáng)指向的Block
調(diào)用Blcok
執(zhí)行效果

如圖:發(fā)現(xiàn)oneVC被銷毀了炼鞠,說(shuō)明,自己定義的Block轰胁,里面使用了self谒主,并不一定會(huì)發(fā)生循環(huán)引用!

原理:block --> 強(qiáng)指向了self赃阀,但是self霎肯,并沒(méi)有指向Block!-->并沒(méi)有一個(gè) self.block 或者 成員變量 @property block 榛斯,所有Block并沒(méi)有被強(qiáng)指向-->沒(méi)有發(fā)送循環(huán)引用观游!

-->Tips:循環(huán)引用發(fā)生的條件就是持有這個(gè)block的對(duì)象,被block里邊加入的對(duì)象持有驮俗。


逼格出現(xiàn)了6啤!華麗分割線王凑! 既然系統(tǒng)的Block搪柑、AFN、都不會(huì)發(fā)生循環(huán)引用索烹,自定義Block又有這么明顯的提示-->實(shí)際開(kāi)發(fā)中不會(huì)遇到循環(huán)引用工碾???

---------------------------------高逼格分割線-----------------------------------------

實(shí)際開(kāi)發(fā)中:使用通知(NSNotifation)百姓,調(diào)用系統(tǒng)自帶的Block渊额,在Block中使用self --> 會(huì)發(fā)生循環(huán)引用。

通知的接收方法

現(xiàn)在iOS的通知已經(jīng)比較好用了垒拢,如圖第二個(gè)方法端圈,我最常用的,特別方便子库,不需要寫(xiě)@selector(方法)+ 調(diào)用舱权,直接寫(xiě)在Block中,就可以實(shí)現(xiàn)接收通知之后實(shí)現(xiàn)的代碼仑嗅。

twoVC發(fā)送通知 --> 給oneVC
oneVC 接收通知
使用通知-發(fā)生循環(huán)引用

如圖宴倍!這才是實(shí)際開(kāi)發(fā)中-->真正有可能發(fā)生循環(huán)引用的地方张症!確實(shí)也是在通知的Block,但是這次的循環(huán)引用并沒(méi)有提示鸵贬,而且也確實(shí)發(fā)生了 --> 這才是真正告訴面試官:我們做過(guò)有實(shí)際開(kāi)發(fā)俗他,并且是在真實(shí)的開(kāi)發(fā)環(huán)境中遇到了-->真正的循環(huán)引用!@啤(不僅僅是面試題講的一個(gè)Block的事兆衅,逼格明顯不夠)

解決辦法-->weakSelf!



最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末嗜浮,一起剝皮案震驚了整個(gè)濱河市羡亩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌危融,老刑警劉巖畏铆,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異吉殃,居然都是意外死亡辞居,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)蛋勺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)瓦灶,“玉大人,你說(shuō)我怎么就攤上這事抱完∫邪幔” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵乾蛤,是天一觀的道長(zhǎng)每界。 經(jīng)常有香客問(wèn)我,道長(zhǎng)家卖,這世上最難降的妖魔是什么眨层? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮趴樱,結(jié)果婚禮上叁征,老公的妹妹穿的比我還像新娘。我一直安慰自己卧秘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布卖陵。 她就那樣靜靜地躺著赶促,像睡著了一般谤祖。 火紅的嫁衣襯著肌膚如雪凸主。 梳的紋絲不亂的頭發(fā)上锋华,一...
    開(kāi)封第一講書(shū)人閱讀 52,457評(píng)論 1 311
  • 那天纳猫,我揣著相機(jī)與錄音尚骄,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的边琉。 我是一名探鬼主播,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼记劝,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼变姨!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起厌丑,我...
    開(kāi)封第一講書(shū)人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤定欧,失蹤者是張志新(化名)和其女友劉穎猜绣,沒(méi)想到半個(gè)月后荧库,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡驶赏,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年耕驰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了爷辱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡朦肘,死狀恐怖饭弓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情媒抠,我是刑警寧澤示启,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站领舰,受9級(jí)特大地震影響夫嗓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜冲秽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一舍咖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧锉桑,春花似錦排霉、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)球订。三九已至,卻和暖如春瑰钮,著一層夾襖步出監(jiān)牢的瞬間冒滩,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工浪谴, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留开睡,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓苟耻,卻偏偏與公主長(zhǎng)得像篇恒,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子凶杖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容