iOS 中捕獲程序崩潰日志

之前聽到朋友面試iOS開發(fā)時(shí)候,被問到關(guān)于已發(fā)布程序崩潰的時(shí)候怎么處理?

我說很簡單吖,友盟還有一些第三方框架都可以幫我們集成、收集到崩潰日志信息;朋友說不是,人家面試官是問這些內(nèi)部怎么實(shí)現(xiàn)的或者讓你寫你要怎么做?

這個(gè)真心沒深究過,今天看了下挺有意思的,分享給大家,參考下面的文章嘍~

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

1. 在程序啟動(dòng)時(shí)加上一個(gè)異常捕獲監(jiān)聽,用來處理程序崩潰時(shí)的回調(diào)動(dòng)作

NSSetUncaughtExceptionHandler (&UncaughtExceptionHandler);

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

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

2. 實(shí)現(xiàn)自己的處理函數(shù)

void UncaughtExceptionHandler(NSException *exception) {

NSArray *arr = [exception callStackSymbols];//得到當(dāng)前調(diào)用棧信息

NSString *reason = [exception reason];//非常重要,就是崩潰的原因

NSString *name = [exception name];//異常類型

NSLog(@"exception type : %@ \n crash reason : %@ \n call stack info : %@", name, reason, arr);

}

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

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

1. 將崩潰信息持久化在本地,下次程序啟動(dòng)時(shí),將崩潰信息作為日志發(fā)送給開發(fā)者。

2. 通過郵件發(fā)送給開發(fā)者。 不過此種方式需要得到用戶的許可,因?yàn)閕OS不能后臺發(fā)送短信或者郵件,會彈出發(fā)送郵件的界面,只有用戶點(diǎn)擊了發(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報(bào)告&body=感謝您的配合!

"

"錯(cuò)誤詳情:%@",

crashLogInfo];

NSURL *url = [NSURL URLWithString:[urlStr stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]];

[[UIApplication sharedApplication] openURL:url];

以上就是iOS中捕獲異常常用的方法,大家可以不妨一試!

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

相關(guān)閱讀更多精彩內(nèi)容

  • iOS開發(fā)中遇到程序崩潰是很正常的事情,如何在程序崩潰時(shí)捕獲到異常信息并通知開發(fā)者,是大多數(shù)軟件都選擇的方法。下面...
    starfox寒流閱讀 1,575評論 0 9
  • iOS開發(fā)中遇到程序崩潰是很正常的事情,如何在程序崩潰時(shí)捕獲到異常信息并通知開發(fā)者,是大多數(shù)軟件都選擇的方法。下面...
    Courage_SC閱讀 2,450評論 9 7
  • iOS開發(fā)中遇到程序崩潰是很正常的事情, 如何獲取到崩潰的原因并且解決, 是每個(gè)程序員應(yīng)該做的事情, 可以做如下操...
    i愛吃土豆的貓閱讀 313評論 0 0
  • 我們這里介紹兩中方法,一種通過后臺寫接口,另一種是通過用戶來給開發(fā)者發(fā)郵件的形式來分析崩潰信息。下面開始介紹第一種...
    EncourageMan閱讀 782評論 0 2
  • - 01 - “迷茫”,曾幾何時(shí),變成了一個(gè)特別酷的詞。誰的青春不迷茫,好像,迷茫真的成為了理所當(dāng)然的事情,成為了...
    嘻哈小子閱讀 345評論 0 0

友情鏈接更多精彩內(nèi)容