Xcode8 使用Instruments檢測(cè)定位并解決iOS內(nèi)存泄漏問題

緣由

最近公司項(xiàng)目更新了幾個(gè)版本,主要是客戶端配合H5上一些活動(dòng)和優(yōu)化解決一些遺留下來的問題琅拌。review代碼的過程中缨伊,發(fā)現(xiàn)項(xiàng)目在模擬器里跑時(shí)內(nèi)存使用很大,達(dá)到了130多兆进宝,趁著剛發(fā)完新版有點(diǎn)空隙刻坊,于是花了點(diǎn)時(shí)間研究了下。

雖然蘋果出了ARC(自動(dòng)內(nèi)存管理機(jī)制)党晋,我們不用花太多的時(shí)間在內(nèi)存泄漏的問題上紧唱,但在我們開發(fā)的過程中活尊,還是會(huì)因?yàn)楦鞣N原因而產(chǎn)生內(nèi)存泄漏,例如Block的循環(huán)引用漏益,delegate 寫成了 strong蛹锰,定時(shí)器沒有關(guān)閉,弱指針使用不當(dāng)?shù)鹊?/em>绰疤。
所以我們下面就簡(jiǎn)單介紹下怎么使用Xcode8自帶的Instruments中的Leaks檢測(cè)我們的程序有沒有內(nèi)存泄露和定位內(nèi)存泄露的代碼铜犬,讓我們可以更準(zhǔn)確的定位和解決問題
(分析內(nèi)存泄露不能把所有的內(nèi)存泄露查出來,有的內(nèi)存泄露是在運(yùn)行時(shí)轻庆,用戶操作時(shí)才產(chǎn)生的)

Leaks具體使用

leaks如何使用癣猾?寫的比較詳細(xì),步驟也很簡(jiǎn)單余爆,感謝網(wǎng)友分享方便瀏覽纷宇,下面也簡(jiǎn)單的寫下步驟

1、打開Leaks(兩種方式)

方式一:


打開Instruments蛾方,選擇Leaks

方式二:


點(diǎn)擊之后等待幾分鐘像捶,會(huì)出現(xiàn)選擇如下圖,選擇choose即可

2桩砰、使用Leaks

完成步驟1之后拓春,就能看到我們應(yīng)用的體檢結(jié)果了(這里僅僅指內(nèi)存泄漏;點(diǎn)擊那個(gè)紅叉標(biāo)識(shí)顯示具體的leaks亚隅,如下圖)


哇硼莽,運(yùn)行應(yīng)用之后,還沒操作頁(yè)面呢煮纵,就這么多內(nèi)存泄漏懂鸵,也難怪模擬器跑的時(shí)候內(nèi)存占用那么多。問題是找出來行疏,但是這樣的信息真的看不懂啊匆光,怎么辦呢?不急隘擎,其實(shí)很簡(jiǎn)單殴穴,設(shè)置一個(gè)地方就好凉夯。

3货葬、設(shè)置Leaks,查找定位具體leak是什么

現(xiàn)在我們就能看出個(gè)大概究竟了劲够,我這個(gè)項(xiàng)目里一看就知道是自己封裝的AFNeteworking有問題震桶。當(dāng)然此時(shí)你還可以選中某一條雙擊,就能定位到具體代碼處征绎,如下圖.

4蹲姐、解決leak

后來仔細(xì)看了下該文件的這個(gè)方法磨取,不難發(fā)現(xiàn)確實(shí)有問題。(注意注釋if語(yǔ)句柴墩,若不加if語(yǔ)句忙厌,每次請(qǐng)求接口都創(chuàng)建一個(gè)session對(duì)象,又沒釋放江咳,那自然就造成了內(nèi)存泄漏逢净。還有session的一些設(shè)置里面,道理也是一樣歼指。)

//數(shù)據(jù)請(qǐng)求爹土,post和get
- (void)requestWithMethod:(RequestMethod)requestMethod
             andUrlString:(NSString *)urlString
            andParameters:(id) parameters
                  success:(CompletePost)success
                  failure:(CompleteFailure)failure
{
    //session存在的話,不需要重復(fù)創(chuàng)建該對(duì)象踩身,解決內(nèi)存leak問題
//    if (!session) {
        session = [AFHTTPSessionManager manager];
        //設(shè)置自定義代理參數(shù)
        [session.requestSerializer setValue:[StaticTools setUserAgentWithParam:@"afn"] forHTTPHeaderField:@"User-Agent"];
        session.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json", @"text/json", @"text/javascript",@"multipart/form-data",@"text/plain", nil];
        //配置https
        session.securityPolicy = [self customSecurityPolicy];
        session.securityPolicy.allowInvalidCertificates = YES;
//    }
    
    if (requestMethod == get) {
        //[self addParaWithOriginDic:parameters] ,判斷參數(shù)是否帶token胀茵,若有的話 添加隨機(jī)數(shù)和簽名參數(shù)
        [session GET:urlString parameters:[self addParaWithOriginDic:parameters] progress:^(NSProgress * _Nonnull downloadProgress) {
            
        } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
            success(responseObject);
        } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
            failure(error);
        }];
    } else {
        [session POST:urlString parameters:[self addParaWithOriginDic:parameters] progress:^(NSProgress * _Nonnull uploadProgress) {
            
        } success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
            success(responseObject);
        } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
            failure(error);
            if (error.code == -1001) {
                //做超時(shí)之后的一些操作
            }
        }];
    }
}

放開if之后,再次檢測(cè)挟阻,發(fā)現(xiàn)之前那么多l(xiāng)eaks都不見了琼娘,果真是這個(gè)問題導(dǎo)致。(下圖雖然還有l(wèi)eak赁濒,但是一看就知道是集成的第三方微客服那邊的問題轨奄,已反饋)


結(jié)果

再次在模擬器上跑的時(shí)候,發(fā)現(xiàn)內(nèi)存確實(shí)也小了很多拒炎,70的樣子挪拟,比之前的130多確實(shí)少多了(真機(jī)上運(yùn)行內(nèi)存在40的樣子)

結(jié)語(yǔ):存在leaks雖然貌似不會(huì)影響App的審核,平時(shí)用的時(shí)候也沒出現(xiàn)奔潰击你,但是干掉leaks玉组,能健壯咋們的app,減少應(yīng)用奔潰閃退的概率丁侄,挺好惯雳!

其它參考鏈接:http://www.cnblogs.com/BigFeng/p/6178301.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市鸿摇,隨后出現(xiàn)的幾起案子石景,更是在濱河造成了極大的恐慌,老刑警劉巖拙吉,帶你破解...
    沈念sama閱讀 221,820評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件潮孽,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡筷黔,警方通過查閱死者的電腦和手機(jī)往史,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,648評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來佛舱,“玉大人椎例,你說我怎么就攤上這事挨决。” “怎么了订歪?”我有些...
    開封第一講書人閱讀 168,324評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵脖祈,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我刷晋,道長(zhǎng)撒犀,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,714評(píng)論 1 297
  • 正文 為了忘掉前任掏秩,我火速辦了婚禮或舞,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蒙幻。我一直安慰自己映凳,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,724評(píng)論 6 397
  • 文/花漫 我一把揭開白布邮破。 她就那樣靜靜地躺著诈豌,像睡著了一般。 火紅的嫁衣襯著肌膚如雪抒和。 梳的紋絲不亂的頭發(fā)上矫渔,一...
    開封第一講書人閱讀 52,328評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音摧莽,去河邊找鬼庙洼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛镊辕,可吹牛的內(nèi)容都是我干的油够。 我是一名探鬼主播,決...
    沈念sama閱讀 40,897評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼征懈,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼石咬!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起卖哎,我...
    開封第一講書人閱讀 39,804評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤鬼悠,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后亏娜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體焕窝,經(jīng)...
    沈念sama閱讀 46,345評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,431評(píng)論 3 340
  • 正文 我和宋清朗相戀三年照藻,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了袜啃。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片汗侵。...
    茶點(diǎn)故事閱讀 40,561評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡幸缕,死狀恐怖群发,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情发乔,我是刑警寧澤熟妓,帶...
    沈念sama閱讀 36,238評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站栏尚,受9級(jí)特大地震影響起愈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜译仗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,928評(píng)論 3 334
  • 文/蒙蒙 一抬虽、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧纵菌,春花似錦阐污、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,417評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至序苏,卻和暖如春手幢,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背忱详。 一陣腳步聲響...
    開封第一講書人閱讀 33,528評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工围来, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人匈睁。 一個(gè)月前我還...
    沈念sama閱讀 48,983評(píng)論 3 376
  • 正文 我出身青樓管钳,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親软舌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子才漆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,573評(píng)論 2 359

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

  • 提供了基于Swift3.0模仿的新浪微博的Demo,大家可以下載看一看:基于Swift3.0高仿的微博客戶端,里面...
    skylor閱讀 6,876評(píng)論 7 20
  • 簡(jiǎn)介: 雖然蘋果出了ARC(自動(dòng)內(nèi)存管理機(jī)制)佛点,我們不用花太多的時(shí)間在內(nèi)存泄漏的問題上醇滥,但在我們開發(fā)的過程中,還是...
    RM_乾笙閱讀 2,489評(píng)論 4 22
  • 先來一發(fā)蘋果官網(wǎng)上Instruments User Guide超营,其實(shí)沒啥用鸳玩,英語(yǔ)不好的也懶得去看。(反正我是看不懂...
    和玨貓閱讀 29,954評(píng)論 51 376
  • 內(nèi)存管理的目的就是讓我們?cè)陂_發(fā)中怎么有效的避免我們的應(yīng)用出現(xiàn)內(nèi)存泄漏的問題。內(nèi)存泄漏大家都不陌生了,簡(jiǎn)單粗俗的講慨飘,...
    宇宙只有巴掌大閱讀 2,364評(píng)論 0 12
  • 誰在布局 (Ⅰ) “為什么選我济丘?” “你跟我們都熟腾仅÷眩”老章說宋梧,“事成之后刨疼,三環(huán)內(nèi)你選套房子虐译”癜澹” 老章要我牽線幫他收...
    啊雁閱讀 249評(píng)論 0 3