iOS開發中遇到程序崩潰是很正常的事情, 如何獲取到崩潰的原因并且解決, 是每個程序員應該做的事情, 可以做如下操作實現:
-
在程序啟動時加上一個異常捕獲監聽,用來處理程序崩潰時的回調動作
NSSetUncaughtExceptionHandler (&UncaughtExceptionHandler);官方文檔介紹:Sets the top-level error-handling function where you can perform last-minute logging before the program terminates.
UncaughtExceptionHandler是一個函數指針,該函數需要我們實現,可以取自己想要的名字。當程序發生異常崩潰時,該函數會得到調用,這跟C,C++中的回調函數的概念是一樣的。
-
實現自己的處理函數
- (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); }
以上代碼很簡單,但是帶來的作用是非常大的。
獲取到了崩潰的日子,如何發送給開發者呢,目前一般有以下兩種方式:
將崩潰信息持久化在本地,下次程序啟動時,將崩潰信息作為日志發送給開發者。
-
通過郵件發送給開發者。 不過此種方式需要得到用戶的許可,因為iOS不能后臺發送短信或者郵件,會彈出發送郵件的界面,只有用戶點擊了發送才可發送。 不過,此種方式最符合蘋果的用戶至上的原則。
發送郵件代碼也很簡單:NSString *crashLogInfo = [NSString stringWithFormat:@"exception type : %@ \n crash reason : %@ \n call stack info : %@", name, reason, arr]; NSString *urlStr = [NSString stringWithFormat:@"mailto://tianranwuwai@yeah.net?subject=bug報告&body=感謝您的配合!" "錯誤詳情:%@", crashLogInfo]; NSURL *url = [NSURL URLWithString:[urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]]; [[UIApplication sharedApplication] openURL:url];
以上就是iOS中捕獲異常常用的方法,大家可以不妨一試!