如何讓iOS Crash Report可讀 (Symbolication)

在進行iOS Crash Report可讀化之前,有幾樣東西是必須的:

1. 應用的app文件,比如Foo.app
2. 應用的dSYM文件,比如Foo.app.dSYM
3. 崩潰報告,比如xxx.crash

頭兩個文件是在后綴名為xcarchive的文件中找到,每個發(fā)布的應用都會生成xcarchive文件。
Crash Report的來源比較多,一個是Xcode,一個是iTunes Connect,還有在手機上也可以獲得。
這三個文件必須要屬于同一個版本的,否則就沒有用了。

把這三個文件放到一個文件夾里,然后查看這個崩潰報告中的程序起始地址,比如說0x2a000. 這個起始地址怎么找呢?在Crash Report文件中找Binary Images部分,第一個地址就是起始地址。

cd到這個文件夾,接下去運行

xcrun atos -o Foo.app/Foo -arch armv7s -l 0x2a000 0x000e6f8b

這樣就能獲得地址0x000e6f8b的錯誤信息了。

這里的參數(shù)-arch參數(shù)由崩潰報告中的Hardware Model確定;

armv6設備:iPhone, iPhone2, iPhone 3G,第一代、第二代iPod Touch

armv7設備:iPhone 3GS, iPhone 4, iPhone 4S, iPad , iPad 2,? the new iPad, iPod Touch 3G, iPod Touch 4

armv7s設備:iPhone 5之后的設備

所以現(xiàn)在這里多數(shù)是armv7s.

如果你想把錯誤文本輸出到一個文件,那么就參考下面的命令:

xcrun atos -o Foo.app/Foo -arch armv7s -l 0x2a000 -f addr.txt

怎么樣確定你的定位是正確的,這里有一個方法來確定main函數(shù)的定位,如果main函數(shù)對了,那么其他的應該也沒有問題。

在crash report中的Thread 0部分的倒數(shù)第二行一般都是main函數(shù),比如

13? KVOdemo? ? ? ? ? ? ? ? ? ? ? 0x000320c6 0x2a000 + 32966

這時候的可讀化應該是main函數(shù),如果是其它的函數(shù),那么就要注意了??纯词遣皇菂?shù)又問題,一個是起始地址(-l 參數(shù)),還有就是arch參數(shù)(-arch參數(shù))。


在我們?nèi)粘5拈_發(fā)過程中其實沒有那么麻煩,一個如果測試的設備在身邊,連上Xcode就可以直接查看device 的crash logs。

還有我們也可以在代碼里面添加Exception Handler來處理這些個問題。

//在didFinishLaunchingWithOptions方法中聲明,在debug模式的時候增加這個功能
#ifdef DEBUG
? ? ? ? NSSetUncaughtExceptionHandler(&UncaughtExceptionHandler);
#endif

//獲取異常崩潰信息
void UncaughtExceptionHandler(NSException *exception) {
? ? NSArray *callStack = [exception callStackSymbols];
? ? NSString *reason = [exception reason];
? ? NSString *name = [exception name];
? ? NSString *content = [NSString stringWithFormat:@"========異常錯誤報告========\nname:%@\nreason:\n%@\ncallStackSymbols:\n%@",name,reason,[callStack componentsJoinedByString:@"\n"]];
//在測試模式的時候,把異常崩潰信息發(fā)送至開發(fā)者郵件
? ? NSMutableString *mailUrl = [NSMutableString string];
? ? [mailUrl appendString:@"mailto:developer@qq.com"];
? ? [mailUrl appendString:@"?subject=程序異常崩潰,請配合發(fā)送異常報告,謝謝合作!"];
? ? [mailUrl appendFormat:@"&body=%@", content];
? ? NSString *mailPath = [mailUrl stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
? ? [[UIApplication sharedApplication] openURL:[NSURL URLWithString:mailPath]];
}

當出現(xiàn)問題的時候讓測試人員直接把錯誤文本發(fā)到你的郵箱就可以了。這樣就節(jié)省了時間。不過這里的定位信息沒有那么明確。但是基本上可以定位你的錯誤。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容