码迷,mamicode.com
首页 > 移动开发 > 详细

iOS 中捕获程序崩溃日志

时间:2015-05-23 18:28:13      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:ios   异常   exception   

iOS开发中遇到程序崩溃是很正常的事情,如何在程序崩溃时捕获到异常信息并通知开发者,是大多数软件都选择的方法。下面就介绍如何在iOS中实现:

1. 在程序启动时加上一个异常捕获监听,用来处理程序崩溃时的回调动作
  NSSetUncaughtExceptionHandler(&UncaughtExceptionHandler);
  官方文档介绍:Sets the top-level error-handlingfunction where you can perform last-minute logging before theprogram 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);
}

以上代码很简单,但是带来的作用是非常大的。

获取到了崩溃的日子,如何发送给开发者呢,目前一般将崩溃信息持久化在本地,下次程序启动时,将崩溃信息作为日志发送给开发者。 

  NSString * strM = [NSString stringWithFormat:@"myexception type : %@ \n crash reason : %@ \n call stack info : %@", name, reason, arr];

    [[NSUserDefaults standardUserDefaults] setObject:strM forKey:@"EXCEPTION"];

    [[NSUserDefaults standardUserDefaults]synchronize];

iOS 中捕获程序崩溃日志

标签:ios   异常   exception   

原文地址:http://blog.csdn.net/u014202635/article/details/45935625

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!