iOS開發-捕獲程序崩潰日誌

 

 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://tianranwuwai@yeah.net?subject=bug報告&body=感謝您的配合!


"
                        "錯誤詳情:%@",
                        crashLogInfo];
    NSURL *url = [NSURL URLWithString:[urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];
    [[UIApplication sharedApplication] openURL:url];

以上就是iOS中捕獲異經常用的方法,你們能夠不妨一試!函數

相關文章
相關標籤/搜索