25iOS中捕获程序崩溃日志

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中捕获异常常用的方法,大家可以不妨一试!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 之前听到朋友面试iOS开发时候,被问到关于已发布程序崩溃的时候怎么处理? 我说很简单吖,友盟还有一些第三方框架都可...
    白屏阅读 1,259评论 2 49
  • iOS开发中遇到程序崩溃是很正常的事情,如何在程序崩溃时捕获到异常信息并通知开发者,是大多数软件都选择的方法。下面...
    Courage_SC阅读 2,409评论 9 7
  • 我们这里介绍两中方法,一种通过后台写接口,另一种是通过用户来给开发者发邮件的形式来分析崩溃信息。下面开始介绍第一种...
    EncourageMan阅读 696评论 0 2
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,268评论 19 139
  • 1、OC语言的基本特点 优缺点 objc优点: 1) Cateogies 2) Posing 3) 动态识别(多态...
    cocoaZ阅读 508评论 0 3