iOS @try @catch @finally 异常捕获的处理

@try @catch @finally

首先我们平时访问数组 越界 或者野指针的时候 很有可能会造成系统的崩溃 app闪退,这么对用户的体验很差。
我们可以用@try方法 来捕获异常 来降低崩溃的频率 提高用户体验、或者通过发送邮件的方式告诉开发者崩溃信息

NSArray *arr = [NSArray array];
    //如果感觉访问的数组会出现问题 可以采取 @try
    @try {
        NSLog(@"11");
        //访问越界数组的值
        NSString *str = arr[1];
        //如果上面的语句发生了异常  那么 44就不会打印
        NSLog(@"44");
        
    }@catch(NSException *exception) {
        NSLog(@"22");
    }
    @finally {
        NSLog(@"33");
    }

//这个处理就不会崩溃 但是 44不会打印
这个代码的执行顺序是  11 -- 22 -- 33 
//如果@try里面没有捕获到异常 那么代码的执行顺序是 11 --- 44 -- 33      @catch里面的代码22不会执行

总的来说就是 @try @finally的代码肯定会执行
@catch里面捕获的代码 就可以处理异常 比如写到沙盒 或者发送邮件跟开发者 这么就可以方便开发人员定位到bug

接下来看如何接收和处理系统的崩溃日志

1.首先定义一个拦截系统异常的函数

//拦截异常
void handleException(NSException *exception){
    
    NSMutableDictionary * info = [NSMutableDictionary dictionary];
    info[@"callStack"] = [exception callStackSymbols];//调用栈信息(错误来源哪个方法)
    info[@"name"] = [exception name];//异常名字
    info[@"reason"] = [exception reason];//异常描述
    
    //    [info writeToFile:<#(nonnull NSString *)#> atomically:<#(BOOL)#>]  写入沙盒
    
    NSLog(@"%@-----%s",exception, __func__);
}


2.调用系统的方法 拦截捕获异常 去调用自己设置的方法

//设置来接系统的异常
     NSSetUncaughtExceptionHandler(handleException);



发现有@try @cathc 嵌套使用的
- (void)tryOne {
    @try {
        // 1
        [self tryTwo];
    }
    @catch (NSException *exception) {
        // 2
        NSLog(@"22222");
        NSLog(@"%s\n%@", __FUNCTION__, exception);
        //        @throw exception; // 这里不能再抛异常
    }
    @finally {
        // 3
        NSLog(@"我一定会执行");
    }
    // 4
    // 这里一定会执行
    NSLog(@"try");
}

- (void)tryTwo
{
    @try {
        // 5
        NSString *str = @"abc";
        [str substringFromIndex:111]; // 程序到这里会崩
    }
    @catch (NSException *exception) {
        // 6
                @throw exception; // 抛出异常,即由上一级处理
        // 7
        NSLog(@"%s\n%@", __FUNCTION__, exception);
    }
    @finally {
        // 8
        NSLog(@"tryTwo - 我一定会执行");
    }
    
    // 9
    // 如果抛出异常,那么这段代码则不会执行
    NSLog(@"如果这里抛出异常,那么这段代码则不会执行");
}


githubDemo: https://github.com/rjb0514/tryCatchDemo

//如果有错误的 或者更好的理解请联系我
邮箱:rujianbin123@163.com

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341

推荐阅读更多精彩内容