西西軟件園多重安全檢測下載網(wǎng)站、值得信賴的軟件下載站!
軟件
軟件
文章
搜索

首頁編程開發(fā)其它知識 → iOS內(nèi)存錯誤EXC_BAD_ACCESS的解決方法

iOS內(nèi)存錯誤EXC_BAD_ACCESS的解決方法

相關(guān)軟件相關(guān)文章發(fā)表評論 來源:西西整理時間:2013/6/23 9:08:24字體大小:A-A+

作者:西西點擊:36次評論:0次標(biāo)簽: 內(nèi)存錯誤

  • 類型:系統(tǒng)其它大。345KB語言:中文 評分:5.0
  • 標(biāo)簽:
立即下載

iOS開發(fā),最郁悶的莫過于程序毫無征兆地就崩潰了,用bt命令打出調(diào)用棧,給出的是一堆系統(tǒng)EXC_BAD_ACCESS的信息,根本沒辦法定位問題出現(xiàn)在哪里。 首先說一下 EXC_BAD_ACCESS 這個錯誤,可以這么說,90%的錯誤來源在于對一個已經(jīng)釋放的對象進(jìn)行release操作。舉一個簡單的例子來說明吧,首先看一段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ù)釋放了某個地址空間。而怎樣定位到這個地址呢,可以通過編輯xcode的scheme,添加如下標(biāo)記位,讓系統(tǒng)把錯誤地址打印出來,如圖:

(通過Product->Scheme->Edit Scheme進(jìn)入下面編輯頁面,選中Arguments tab,增加標(biāo)計位NSZombieEnabled設(shè)為YES)

這樣,但崩潰出現(xiàn),系統(tǒng)會出現(xiàn)以下提示信息:

2013-06-23 00:45:20.479 *** -[__NSArrayM addObject:]: message sent to deallocated instance 0x7179910

可見崩潰原因是內(nèi)存地址0x7179910被重復(fù)釋放了。

Objective-C 這段代碼有三個致命問題:1、內(nèi)存泄露;2、錯誤釋放;3、造成 EXC_BAD_ACCESS 錯誤。

如果崩潰是發(fā)生在當(dāng)前調(diào)用棧,通過上面的做法,系統(tǒng)就會把崩潰原因定位到具體代碼中。但是,如果崩潰不在當(dāng)前調(diào)用棧,系統(tǒng)就僅僅只能把崩潰地址告訴我們,而沒辦法定位到具體代碼,這樣我們也沒法去修改錯誤。這時就可以修改scheme,讓xcode記錄每個地址alloc的歷史,這樣我們就可以用命令把這個地址還原出來。如圖:(跟設(shè)置NSZombieEnabled一樣,添加MallocStackLoggingNoCompact,并且設(shè)置為YES)

這樣,當(dāng)出現(xiàn)崩潰原因是message sent to deallocated instance 0x7179910,我們可以使用以下命令,把內(nèi)存地址還原:

info malloc-history 0x7179910

如圖,這個命令能具體把這個地址在哪一行代碼生成還原出來。

(需要注意的是,因為這個命令只支持gdb,所以必須把控制臺的輸出改成gdb,并且有點遺憾的是,只支持模擬器,不支持真機調(diào)試)

(同樣是通過Product->Scheme->Edit Scheme進(jìn)入上面編輯頁面,選中Info tab)

這樣,好好檢查一下那一行的代碼,應(yīng)該就很容易找出問題所在了。

    相關(guān)評論

    閱讀本文后您有什么感想? 已有人給出評價!

    • 8 喜歡喜歡
    • 3 頂
    • 1 難過難過
    • 5 囧
    • 3 圍觀圍觀
    • 2 無聊無聊

    熱門評論

    最新評論

    發(fā)表評論 查看所有評論(0)

    昵稱:
    表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
    字?jǐn)?shù): 0/500 (您的評論需要經(jīng)過審核才能顯示)