標籤:
iOS 中捕獲程式崩潰日誌 (2014-04-22 17:35:59)
轉載▼
iOS開發中遇到程式崩潰是很正常的事情,如何在程式崩潰時捕獲到異常資訊並通知開發人員,是大多數軟體都選擇的方法。下面就介紹如何在iOS中實現:
1. 在程式啟動時加上一個異常捕獲監聽,用來處理常式崩潰時的回調動作
NSSetUncaughtExceptionHandler (&UncaughtExceptionHandler);
官方文檔介紹:Sets the top-level error-handling function where you can perform last-minute logging before the program terminates.
UncaughtExceptionHandler是一個函數指標,該函數需要我們實現,可以取自己想要的名字。當程式發生異常崩潰時,該函數會得到調用,這跟C,C++中的回呼函數的概念是一樣的。
2. 實現自己的處理函數
void UncaughtExceptionHandler(NSException *exception) {
NSArray *arr = [exception callStackSymbols];//得到當前調用棧資訊
NSString *reason = [exception reason];//非常重要,就是崩潰的原因
NSString *name = [exception name];//異常類型
NSLog(@"exception type : %@ \n crash reason : %@ \n call stack info : %@", name, reason, arr);
}
以上代碼很簡單,但是帶來的作用是非常大的。
擷取到了崩潰的日子,如何發送給開發人員呢,目前一般有以下兩種方式:
1. 將崩潰資訊持久化在本地,下次程式啟動時,將崩潰資訊作為日誌發送給開發人員。
2. 通過郵件發送給開發人員。 不過此種方式需要得到使用者的許可,因為iOS不能後台傳送簡訊或者郵件,會彈出發送郵件的介面,只有使用者點擊了發送才可發送。 不過,此種方式最符合蘋果的以使用者至上的原則。
發送郵件代碼也很簡單:
NSString *crashLogInfo = [NSString stringWithFormat:@"exception type : %@ \n crash reason : %@ \n call stack info : %@", name, reason, arr];
NSString *urlStr = [NSString stringWithFormat:@"mailto://[email protected]?subject=bug報告&body=感謝您的配合!
"
"錯誤詳情:%@",
crashLogInfo];
NSURL *url = [NSURL URLWithString:[urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
[[UIApplication sharedApplication] openURL:url];
以上就是iOS中捕獲異常常用的方法,大家可以不妨一試!
iOS 中捕獲程式崩潰日誌