iOS 中捕獲程序崩潰日志

iOS開發(fā)中遇到程序崩潰是很正常的事情,如何在程序崩潰時捕獲到異常信息并通知開發(fā)者,是大多數(shù)軟件都選擇的方法。下面就介紹如何在iOS中實現(xiàn):

  1. 在程序啟動時加上一個異常捕獲監(jiān)聽,用來處理程序崩潰時的回調動作NSSetUncaughtExceptionHandler (&UncaughtExceptionHandler);

官方文檔介紹:Sets the top-level error-handling function where you can perform last-minute logging before the program terminates.

UncaughtExceptionHandler是一個函數(shù)指針,該函數(shù)需要我們實現(xiàn),可以取自己想要的名字。當程序發(fā)生異常崩潰時,該函數(shù)會得到調用,這跟C,C++中的回調函數(shù)的概念是一樣的。

  1. 實現(xiàn)自己的處理函
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);
}

以上代碼很簡單,但是帶來的作用是非常大的。

獲取到了崩潰的日子,如何發(fā)送給開發(fā)者呢,目前一般有以下兩種方式:

  1. 將崩潰信息持久化在本地,下次程序啟動時,將崩潰信息作為日志發(fā)送給開發(fā)者。
  2. 通過郵件發(fā)送給開發(fā)者。 不過此種方式需要得到用戶的許可,因為iOS不能后臺發(fā)送短信或者郵件,會彈出發(fā)送郵件的界面,只有用戶點擊了發(fā)送才可發(fā)送。 不過,此種方式最符合蘋果的以用戶至上的原則。
    發(fā)送郵件代碼也很簡單:
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中捕獲異常常用的方法,大家可以不妨一試!

Written with StackEdit.

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

相關閱讀更多精彩內容

友情鏈接更多精彩內容