在進行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é)省了時間。不過這里的定位信息沒有那么明確。但是基本上可以定位你的錯誤。