iOS 異常初探

雖然我們都不想我們編寫的應(yīng)用發(fā)生crash,但是crash是在所難免的市埋。iOS系統(tǒng)對(duì)于crash有兩種處理方式肌蜻,一種是由EXC_BAD_ACCESS引起的互墓,多為內(nèi)存問題;另一種是未被捕獲的Objective-C異常(NSException)蒋搜,導(dǎo)致程序向自身發(fā)送了SIGABRT信號(hào)而崩潰篡撵。我們需要了解一下如何獲取crash信息判莉。

當(dāng)我們想在crash之前做某些操作的時(shí)候比如發(fā)送錯(cuò)誤日志到郵件或者本地保存日志的時(shí)候,我們就可以使用系統(tǒng)的一個(gè)方法去實(shí)現(xiàn)育谬。系統(tǒng)有一個(gè)名為NSSetUncaughtExceptionHandler的方法骂租,是用于注冊(cè)在crash時(shí)調(diào)用什么方法的。一般來說是在- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions這個(gè)方法里去注冊(cè)如

-?(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{

NSSetUncaughtExceptionHandler(要執(zhí)行的函數(shù)名)斑司;

return YES;

}


為了方便使用我們可以定義一個(gè)類來處理異常這個(gè)類繼承NSObject但汞,然后在這個(gè)內(nèi)部注冊(cè)異常處理函數(shù)及實(shí)現(xiàn)想要的操作宿刮。

上面的注冊(cè)換成定義的類的注冊(cè)方法即可例如下面的startLog

#import "MyCrashLog.h"

#import<sys/signal.h>

@implementation MyCrashLog

+ (void)startLog

{

dispatch_once_t one;

dispatch_once(&one, ^{

//注冊(cè)異常

NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);

//可添加信號(hào)量異常注冊(cè)

});

}

static void uncaughtExceptionHandler(NSException *exception)

{

/ NSLog(@"異常:%@---",exception);

截獲到異常 , 發(fā)生crash時(shí)會(huì)自動(dòng)調(diào)用此方法名稱自己可定義 但是要和注冊(cè)的名稱一樣

在此處處理異常私蕾,根據(jù)自己的需求

}

@end

上面的代碼只是注冊(cè)和處理了EXC_BAD_ACCESS異常


要處理SIGABRT信號(hào)也是如同上面一樣注冊(cè)信號(hào)異常只是函數(shù)名不一樣

在上述代碼注冊(cè)的時(shí)候添加類似

//注冊(cè)信號(hào)量

signal(SIGABRT, headleSing);

signal(SIGPROF, headleSing);

signal(SIGPROF, headleSing);

的代碼就可以注冊(cè)相應(yīng)的信號(hào)量了僵缺,其中headleSing為自定義的處理異常的信號(hào)的函數(shù)名

信號(hào)量有很多種可以按需求去注冊(cè)

到此對(duì)于異常的獲取結(jié)束

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市踩叭,隨后出現(xiàn)的幾起案子磕潮,更是在濱河造成了極大的恐慌,老刑警劉巖容贝,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件自脯,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡斤富,警方通過查閱死者的電腦和手機(jī)膏潮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來满力,“玉大人焕参,你說我怎么就攤上這事∮投睿” “怎么了叠纷?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)潦嘶。 經(jīng)常有香客問我涩嚣,道長(zhǎng),這世上最難降的妖魔是什么衬以? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任缓艳,我火速辦了婚禮,結(jié)果婚禮上看峻,老公的妹妹穿的比我還像新娘阶淘。我一直安慰自己,他們只是感情好互妓,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布溪窒。 她就那樣靜靜地躺著坤塞,像睡著了一般。 火紅的嫁衣襯著肌膚如雪澈蚌。 梳的紋絲不亂的頭發(fā)上摹芙,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音宛瞄,去河邊找鬼浮禾。 笑死,一個(gè)胖子當(dāng)著我的面吹牛份汗,可吹牛的內(nèi)容都是我干的盈电。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼杯活,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼匆帚!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起旁钧,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤吸重,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后歪今,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體嚎幸,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年寄猩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鞭铆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡焦影,死狀恐怖车遂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情斯辰,我是刑警寧澤舶担,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站彬呻,受9級(jí)特大地震影響衣陶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜闸氮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一剪况、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蒲跨,春花似錦译断、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽堪唐。三九已至,卻和暖如春翎蹈,著一層夾襖步出監(jiān)牢的瞬間淮菠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國打工荤堪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留合陵,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓澄阳,卻偏偏與公主長(zhǎng)得像曙寡,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子寇荧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 轉(zhuǎn)載(漫談 iOS Crash 收集框架) 前言 很早以前就和念茜認(rèn)識(shí),念茜不但技術(shù)功底扎實(shí)执隧,而且長(zhǎng)得很漂亮揩抡,說她...
    狂風(fēng)無跡閱讀 3,298評(píng)論 1 11
  • 以下為文章正文,如果覺得有用镀琉,歡迎給她打賞峦嗤。 為了能夠第一時(shí)間發(fā)現(xiàn)程序問題,應(yīng)用程序需要實(shí)現(xiàn)自己的崩潰日志收集服務(wù)...
    赤色追風(fēng)閱讀 2,548評(píng)論 1 11
  • 來源:程序媛念茜的博客 Crash日志收集 為了能夠第一時(shí)間發(fā)現(xiàn)程序問題屋摔,應(yīng)用程序需要實(shí)現(xiàn)自己的崩潰日志收集服務(wù)烁设,...
    幸福的魚閱讀 1,164評(píng)論 0 2
  • 比較好的轉(zhuǎn)載:http://www.cocoachina.com/ios/20151218/14748.html轉(zhuǎn)...
    liudhkk閱讀 930評(píng)論 0 2
  • 文章目錄 一. 系統(tǒng)Crash 二. 處理signal 下面是一些信號(hào)說明 關(guān)鍵點(diǎn)注意 三. 實(shí)戰(zhàn) 四. Cras...
    MTDeveloper閱讀 1,161評(píng)論 1 2