內(nèi)存泄漏檢測三方庫-MLeaksFinder

iOS性能優(yōu)化是一個比較復(fù)雜的問題顽素,其中之一就是內(nèi)存泄露檢測,很多人會第一時間想到使用Instruments蛔垢。由于學(xué)習(xí)成本比較高嚎于,專業(yè)詳細(xì)的教程也比較少掘而,在學(xué)習(xí)了基本介紹后就望而生畏了挟冠。今天瀏覽了微信讀書團(tuán)隊的技術(shù)博客,發(fā)現(xiàn)了一個非常友好的內(nèi)存泄露檢測庫MLeaksFinder

MLeaksFinder

簡單介紹一下MLeaksFinder袍睡。

官方解釋:

具體的方法是知染,為基類 NSObject 添加一個方法 -willDealloc 方法,該方法的作用是斑胜,先用一個弱指針指向 self持舆,并在一小段時間(3秒)后,通過這個弱指針調(diào)用 -assertNotDealloc伪窖,而 -assertNotDealloc 主要作用是直接中斷言。

核心代碼:

-(BOOL)willDealloc{__weak id weakSelf=self;dispatch_after(dispatch_time(DISPATCH_TIME_NOW,(int64_t)(3*NSEC_PER_SEC)),dispatch_get_main_queue(),^{[weakSelf assertNotDealloc];});returnYES;}-(void)assertNotDealloc{NSAssert(NO,@“”);}

這樣居兆,當(dāng)我們認(rèn)為某個對象應(yīng)該要被釋放了覆山,在釋放前調(diào)用這個方法,如果3秒后它被釋放成功泥栖,weakSelf 就指向 nil簇宽,不會調(diào)用到 -assertNotDealloc 方法,也就不會中斷言吧享,如果它沒被釋放(泄露了)魏割,-assertNotDealloc 就會被調(diào)用中斷言。這樣钢颂,當(dāng)一個 UIViewController 被 pop 或 dismiss 時(我們認(rèn)為它應(yīng)該要被釋放了)钞它,我們遍歷該 UIViewController 上的所有 view,依次調(diào) -willDealloc殊鞭,若3秒后沒被釋放遭垛,就會中斷言。

例如在UIViewController的分類中操灿,使用Method Swizzling锯仪,hook掉了viewDidDisappear:,viewWillAppear:趾盐,dismissViewControllerAnimated:completion:等方法庶喜,讓他們都執(zhí)行willDealloc方法,這樣救鲤,在不入侵開發(fā)代碼的情況下久窟,為UIViewController添加了檢查內(nèi)存泄露的功能(AOP)。

安裝

安裝非常簡單蜒简,直接在Podfile中添加pod 'MLeaksFinder'瘸羡,你不需要在任何文件中引入頭文件,執(zhí)行pod install后搓茬,直接構(gòu)建或者run一下就好了犹赖。

案例

在iOS中队他,比較常見的內(nèi)存泄露場景就是循環(huán)引用。作為一個iOS工程師峻村,應(yīng)該時刻警惕循環(huán)引用帶來的問題麸折。然而在趕工或者稍有不慎的情況下,還是會出現(xiàn)一些有問題的代碼粘昨。

對于Xcode來說垢啼,編譯器會對編寫代碼中明顯的循環(huán)引用進(jìn)行提示,比如對于self.property持有的block中张肾,使用self芭析,Xcode就會顯示警告。但是吞瞪,對于以下代碼馁启,Xcode就不會警告:

LessonWithoutJobCell*cell=[tableView dequeueReusableCellWithIdentifier:reusedID1];if(!cell){cell=[[LessonWithoutJobCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:reusedID1];}cell.model=model;[cell setEnterBlock:^{if(self.classBlock){self.classBlock(model);}}];returncell;

在tableView中的某一個cell,持有了一個block芍秆,在block中使用了self.classBlock惯疙,乍一看好像沒有問題啊。

真的沒有問題嗎妖啥?

在這個控制器被pop后霉颠,MLeaksFinder立刻就彈出了彈窗

IMG_6481.PNG

點擊Retain Cycle

IMG_6479.PNG

仔細(xì)想想,真的是出現(xiàn)循環(huán)引用荆虱。首先是self引用了tableView蒿偎,tableView引用了cell,cell中的block引用了self怀读,這樣酥郭,在控制器被pop之后,這個view還存在著強(qiáng)引用愿吹,這樣它的內(nèi)存就得不到釋放不从,這樣就造成了循環(huán)引用,經(jīng)歷頻繁的push和pop操作后犁跪,內(nèi)存將會暴增椿息。其實這是一個很低級的bug了,但是稍不注意坷衍,就被忽略了寝优。

既然發(fā)現(xiàn)了問題,解決循環(huán)引用就非常簡單了枫耳。在cell的block外面乏矾,把self定義為weak類型,打破循環(huán)引用:

······__weaktypeof(self)weakSelf=self;······//把block中的self換成weakSelf即可[cell setEnterBlock:^{if(weakSelf.classBlock){weakSelf.classBlock(model);}}];

至此,MLeaksFinder的簡單使用就介紹完了钻心,真的十分簡單就找到了一些潛在的問題凄硼,對于工程幾乎0入侵,強(qiáng)烈推薦使用捷沸。

轉(zhuǎn)自鏈接:http://www.reibang.com/p/b8d2f736ae6b

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末摊沉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子痒给,更是在濱河造成了極大的恐慌说墨,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件苍柏,死亡現(xiàn)場離奇詭異尼斧,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)试吁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門突颊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人潘悼,你說我怎么就攤上這事∨老穑” “怎么了治唤?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長糙申。 經(jīng)常有香客問我宾添,道長,這世上最難降的妖魔是什么柜裸? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任缕陕,我火速辦了婚禮,結(jié)果婚禮上疙挺,老公的妹妹穿的比我還像新娘扛邑。我一直安慰自己,他們只是感情好铐然,可當(dāng)我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布蔬崩。 她就那樣靜靜地躺著,像睡著了一般搀暑。 火紅的嫁衣襯著肌膚如雪沥阳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天自点,我揣著相機(jī)與錄音桐罕,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛功炮,可吹牛的內(nèi)容都是我干的溅潜。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼死宣,長吁一口氣:“原來是場噩夢啊……” “哼伟恶!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起毅该,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤博秫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后眶掌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挡育,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年朴爬,在試婚紗的時候發(fā)現(xiàn)自己被綠了即寒。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡召噩,死狀恐怖母赵,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情具滴,我是刑警寧澤凹嘲,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站构韵,受9級特大地震影響周蹭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜疲恢,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一凶朗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧显拳,春花似錦棚愤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至耍休,卻和暖如春刃永,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背羊精。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工斯够, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留囚玫,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓读规,卻偏偏與公主長得像抓督,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子束亏,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,933評論 2 355

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