AFNetworking 踩坑

最近公司的項目把網(wǎng)絡(luò)庫從ASIHTTPRequest 全部替換成了AFNetworking帘靡,但是在iOS 7上遇到了頻率很高的crash啊终。具體崩潰在AFURLSessionManager.h里的[self.mutableData appendData:data];這一行

- (void)URLSession:(__unused NSURLSession *)session
          dataTask:(__unused NSURLSessionDataTask *)dataTask
    didReceiveData:(NSData *)data
{
    [self.mutableData appendData:data];
}

打印的log

malloc: *** error for object 0x633c000: pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug

意思應(yīng)該是mutableData在某處被釋放了沦疾,于是查找所有用到mutableData的地方

- (void)URLSession:(__unused NSURLSession *)session
              task:(NSURLSessionTask *)task
didCompleteWithError:(NSError *)error{
...
    NSData *data = nil;
    if (self.mutableData) {
        data = [self.mutableData copy];
        self.mutableData = nil;
    }
...
}

在這個回調(diào)里mutableData 被釋放掉了绒怨,但是在iOS 7以上的系統(tǒng)卻沒發(fā)現(xiàn)崩潰,應(yīng)該是iOS 7里块攒,同一個task励稳,這兩個方法是在兩個線程異步執(zhí)行的,導(dǎo)致mutableData 提前置為nil囱井。

圖片發(fā)自簡書App

解決辦法

在操作mutableData的地方加鎖麦锯,并且加了版本判斷,崩潰就基本不會復(fù)現(xiàn)了琅绅。

- (void)URLSession:(__unused NSURLSession *)session
          dataTask:(__unused NSURLSessionDataTask *)dataTask
    didReceiveData:(NSData *)data
{
    if ([[[UIDevice currentDevice] systemVersion] floatValue] < 8.0) {
        @synchronized (self.mutableData) {
            if (!self.mutableData) {
                self.mutableData = [NSMutableData data];
            }
            [self.mutableData appendData:data];
        }
    }else{
        [self.mutableData appendData:data];
    }
}
- (void)URLSession:(__unused NSURLSession *)session
              task:(NSURLSessionTask *)task
didCompleteWithError:(NSError *)error
{
...
    NSData *data = nil;
    if (self.mutableData) {
        data = [self.mutableData copy];
        //We no longer need the reference, so nil it out to gain back some memory.
        if ([[[UIDevice currentDevice] systemVersion] floatValue] < 8.0) {//加鎖扶欣,防止崩潰在[self.mutableData appendData:data];
            @synchronized (self.mutableData) {
                self.mutableData = nil;
            }
        }else{
            self.mutableData = nil;
        }
    }
...
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市千扶,隨后出現(xiàn)的幾起案子料祠,更是在濱河造成了極大的恐慌,老刑警劉巖澎羞,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件髓绽,死亡現(xiàn)場離奇詭異,居然都是意外死亡妆绞,警方通過查閱死者的電腦和手機(jī)顺呕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進(jìn)店門枫攀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人株茶,你說我怎么就攤上這事来涨。” “怎么了启盛?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵蹦掐,是天一觀的道長。 經(jīng)常有香客問我僵闯,道長卧抗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任鳖粟,我火速辦了婚禮社裆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘向图。我一直安慰自己浦马,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布张漂。 她就那樣靜靜地躺著晶默,像睡著了一般。 火紅的嫁衣襯著肌膚如雪航攒。 梳的紋絲不亂的頭發(fā)上磺陡,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天,我揣著相機(jī)與錄音漠畜,去河邊找鬼币他。 笑死,一個胖子當(dāng)著我的面吹牛憔狞,可吹牛的內(nèi)容都是我干的蝴悉。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼瘾敢,長吁一口氣:“原來是場噩夢啊……” “哼拍冠!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起簇抵,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤庆杜,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后碟摆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體晃财,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年典蜕,在試婚紗的時候發(fā)現(xiàn)自己被綠了断盛。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片罗洗。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖钢猛,靈堂內(nèi)的尸體忽然破棺而出伙菜,到底是詐尸還是另有隱情,我是刑警寧澤厢洞,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布仇让,位于F島的核電站典奉,受9級特大地震影響躺翻,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜卫玖,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一公你、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧假瞬,春花似錦陕靠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至琴许,卻和暖如春税肪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背榜田。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工益兄, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人箭券。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓净捅,卻偏偏與公主長得像,于是被迫代替她去往敵國和親辩块。 傳聞我的和親對象是個殘疾皇子蛔六,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,446評論 2 348

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

  • *面試心聲:其實這些題本人都沒怎么背,但是在上海 兩周半 面了大約10家 收到差不多3個offer,總結(jié)起來就是把...
    Dove_iOS閱讀 27,128評論 29 470
  • 寫在開頭: 作為一個iOS開發(fā)古今,也許你不知道NSUrlRequest、不知道NSUrlConnection滔以、也不知...
    涂耀輝閱讀 98,669評論 172 1,346
  • (一)1.簡述你對協(xié)議的理解: a想做一件事卻因為一些原因不能做捉腥,于是讓b遵循a的一些約定,這樣b就可以幫助a做事...
    Hither閱讀 5,384評論 27 68
  • 1.內(nèi)存管理 2.單例的理解 3.post和get的區(qū)別 4.md5和base64是什么你画,有什么區(qū)別 5.簡單談?wù)?..
    coder_Wg閱讀 1,285評論 1 6
  • 自己的電腦神舟k610d抵碟,發(fā)現(xiàn)無線網(wǎng)非常不穩(wěn)定桃漾,有時候能搜到wifi卻連不上,有時候連上了卻連不上互聯(lián)網(wǎng)拟逮,于是決定...
    背木劍的溫小二閱讀 3,910評論 0 2