iOS內(nèi)存錯(cuò)誤EXC_BAD_ACCESS的解決方法
iOS開發(fā),最郁悶的莫過于程序毫無征兆地就崩潰了,用bt命令打出調(diào)用棧,給出的是一堆系統(tǒng)EXC_BAD_ACCESS的信息,根本沒辦法定位問題出現(xiàn)在哪里。 首先說一下 EXC_BAD_ACCESS 這個(gè)錯(cuò)誤,可以這么說,90%的錯(cuò)誤來源在于對(duì)一個(gè)已經(jīng)釋放的對(duì)象進(jìn)行release操作。舉一個(gè)簡單的例子來說明吧,首先看一段Java代碼:
public class Test{
public static void main(String[] args){
String s = "This is a test string";
s = s.substring(s.indexOf("a"),(s.length()));
System.out.println(s);
}
}
通常這樣的崩潰出現(xiàn),原因一般就是:調(diào)用了已經(jīng)釋放的內(nèi)存空間,或者說重復(fù)釋放了某個(gè)地址空間。而怎樣定位到這個(gè)地址呢,可以通過編輯xcode的scheme,添加如下標(biāo)記位,讓系統(tǒng)把錯(cuò)誤地址打印出來,如圖:
(通過Product->Scheme->Edit Scheme進(jìn)入下面編輯頁面,選中Arguments tab,增加標(biāo)計(jì)位NSZombieEnabled設(shè)為YES)
這樣,但崩潰出現(xiàn),系統(tǒng)會(huì)出現(xiàn)以下提示信息:
2013-06-23 00:45:20.479 *** -[__NSArrayM addObject:]: message sent to deallocated instance 0x7179910
可見崩潰原因是內(nèi)存地址0x7179910被重復(fù)釋放了。
Objective-C 這段代碼有三個(gè)致命問題:1、內(nèi)存泄露;2、錯(cuò)誤釋放;3、造成 EXC_BAD_ACCESS 錯(cuò)誤。
如果崩潰是發(fā)生在當(dāng)前調(diào)用棧,通過上面的做法,系統(tǒng)就會(huì)把崩潰原因定位到具體代碼中。但是,如果崩潰不在當(dāng)前調(diào)用棧,系統(tǒng)就僅僅只能把崩潰地址告訴我們,而沒辦法定位到具體代碼,這樣我們也沒法去修改錯(cuò)誤。這時(shí)就可以修改scheme,讓xcode記錄每個(gè)地址alloc的歷史,這樣我們就可以用命令把這個(gè)地址還原出來。如圖:(跟設(shè)置NSZombieEnabled一樣,添加MallocStackLoggingNoCompact,并且設(shè)置為YES)
這樣,當(dāng)出現(xiàn)崩潰原因是message sent to deallocated instance 0x7179910,我們可以使用以下命令,把內(nèi)存地址還原:
info malloc-history 0x7179910
如圖,這個(gè)命令能具體把這個(gè)地址在哪一行代碼生成還原出來。
(需要注意的是,因?yàn)檫@個(gè)命令只支持gdb,所以必須把控制臺(tái)的輸出改成gdb,并且有點(diǎn)遺憾的是,只支持模擬器,不支持真機(jī)調(diào)試)
(同樣是通過Product->Scheme->Edit Scheme進(jìn)入上面編輯頁面,選中Info tab)
這樣,好好檢查一下那一行的代碼,應(yīng)該就很容易找出問題所在了。
相關(guān)文章
iOS開發(fā)之tableView實(shí)現(xiàn)左滑刪除功能
我們?cè)谑褂靡恍?yīng)用的時(shí)候,在滑動(dòng)一些聯(lián)系人的某一行的時(shí)候,會(huì)出現(xiàn)刪除、置頂、更多等等的按鈕,下面這篇文章主要就介紹了iOS用tableView實(shí)現(xiàn)左劃刪除功能的方法,有需要的朋友們可以參考借鑒,下面來一起看看吧。2017-01-01iOS開發(fā)中的幾個(gè)手勢(shì)操作實(shí)例分享
這篇文章主要介紹了iOS開發(fā)中的幾個(gè)手勢(shì)操作實(shí)例分享,編寫代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-09-09IOS關(guān)于大型網(wǎng)站搶購、距活動(dòng)結(jié)束,剩余時(shí)間倒計(jì)時(shí)的實(shí)現(xiàn)代碼
這篇文章主要介紹了IOS關(guān)于大型網(wǎng)站搶購、距活動(dòng)結(jié)束,剩余時(shí)間倒計(jì)時(shí)的實(shí)現(xiàn)代碼的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08iOS實(shí)現(xiàn)類似格瓦拉電影的轉(zhuǎn)場動(dòng)畫
這篇文章主要給大家介紹了利用iOS如何實(shí)現(xiàn)類似格瓦拉電影的轉(zhuǎn)場動(dòng)畫,文中給出了詳細(xì)步驟實(shí)現(xiàn)代碼,對(duì)大家的學(xué)習(xí)和理解很有幫助,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-11-11iOS實(shí)現(xiàn)一個(gè)意見反饋類型的輸入欄
這篇文章主要給大家介紹了關(guān)于利用iOS實(shí)現(xiàn)一個(gè)意見反饋類型的輸入欄,通過文中實(shí)現(xiàn)的輸入欄會(huì)用戶一個(gè)很好的體驗(yàn)效果,文中給了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10iOS禁用側(cè)滑返回手勢(shì)要點(diǎn)解析
這篇文章主要為大家詳細(xì)解析了iOS禁用側(cè)滑返回手勢(shì)要點(diǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05