iOS 之 APP 异常崩溃抓取

作者: PanPan1127 | 来源:发表于2016-01-04 14:20 被阅读6817次

    iOS 之 APP 异常崩溃抓取

    NSSetUncaughtExceptionHandler

    自己用程序捕获 crash,保存于本地

    1. 新建一个继承自NSObject的类(Xcode新建一个空项目过程略),取名字CatchCrash,在h和m文件中写下:

      void uncaughtExceptionHandler(NSException *exception)  
      

    {
    // 异常的堆栈信息
    NSArray *stackArray = [exception callStackSymbols];
    // 出现异常的原因
    NSString *reason = [exception reason];
    // 异常名称
    NSString *name = [exception name];
    NSString *exceptionInfo = [NSString stringWithFormat:@"Exception reason:%@\nException name:%@\nException stack:%@",name, reason, stackArray];
    NSLog(@"%@", exceptionInfo);

    NSMutableArray *tmpArr = [NSMutableArray arrayWithArray:stackArray];  
    [tmpArr insertObject:reason atIndex:0];  
      
    //保存到本地  --  当然你可以在下次启动的时候,上传这个log  
    [exceptionInfo writeToFile:[NSString stringWithFormat:@"%@/Documents/error.log",NSHomeDirectory()]  atomically:YES encoding:NSUTF8StringEncoding error:nil];  
    

    }

    ```
    
    1. 添加一个继承自UIViewcontroller的类,取名字为TestViewController。

    2. 注册CatchCrash异常处理方法,在Appdelegate写下如下代码:

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

    {
    self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
    // Override point for customization after application launch.

    //注册消息处理函数的处理方法  
    NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);  
      
    TestViewController *testVc = [[TestViewController alloc] init];  
    self.window.rootViewController = testVc;  
      
    self.window.backgroundColor = [UIColor whiteColor];  
    [self.window makeKeyAndVisible];  
    return YES;  
    

    }

    ```
    
    1. 崩溃闪退后,下次启动 app 时上传该 log 文件内容至服务器即可。

    增强特性

    NSSetUncaughtExceptionHandler 用来做异常处理,但功能非常有限.

    而引起崩溃的大多数原因如:内存访问错误,重复释放等错误就无能为力了,因为这种错误它抛出的是Signal,所以必须要专门做Signal处理

    1. 定义 UncaghtExceptionHandler 类,h 文件:

      @interface UncaughtExceptionHandler : NSObject{
          BOOL dismissed;
      }
      
      void InstallUncaughtExceptionHandler();
      @end
      
      

      m 文件:

      void InstallUncaughtExceptionHandler()
      {
          signal(SIGABRT, MySignalHandler);
          signal(SIGILL, MySignalHandler);
          signal(SIGSEGV, MySignalHandler);
          signal(SIGFPE, MySignalHandler);
          signal(SIGBUS, MySignalHandler);
          signal(SIGPIPE, MySignalHandler);
      }
      
      

    //当 app 发生错误产生如上 signal 后,即会回掉自定义函数MySignalHandler
    具体实现略

    ```
    
    1. 在didFinishLaunchingWithOptions中调用该函数:

      - (void)installUncaughtExceptionHandler
          {
              InstallUncaughtExceptionHandler();
          }
      
      

    综上2步:所有崩溃基本上没问题了。

    获取 crash 闪退日志

    1. XCode 的菜单Window->Organizer 选择Devices -> 选中的手机 -> 点击手机名称左边的箭头

      Unknown和Crash 这两种类型分别是 内存不够回收内存kill应用程序导致Crash和程序异常Crash的日志。

    2. 打开手机 - > 设置 -> 隐私 - > 诊断与用量 - > 诊断与用量数据 这里面就是所有应用的Crash日志。

      先找到存放crash的iphone系统路径:var/mobile/Library/Logs/CrashReporter)找到了crash存放的路径,唉,苦于无法读取(用程序读出来都是nil)

    3. 通过iTunes Connect(Manage Your Applications - View Details - Crash Reports)获取用户的crash日志。

    相关文章

      网友评论

      • Stroman:可是我没看懂
      • Stroman:谢谢,你帮了我的大忙。
      • 云画的跃光:為啥不寫的再清楚點呢?一般都是新手看的吧,既然都寫了,就不要再珍惜那幾個字吧
      • 我的大名叫小爱:有没有demo 啊 .传上来学习下 啊.
      • 郭子岩:是不是有些操作在signal和NSUncaughtExceptionHandler的处理函数中不起作用 比如弹出alertview的提示框就不起作用 而且真机测试的时候并不是发生每个异常都能捕捉到的吧!

      本文标题: iOS 之 APP 异常崩溃抓取

      本文链接:https://www.haomeiwen.com/subject/bthahttx.html