zoukankan      html  css  js  c++  java
  • 关于Xcode不能打印崩溃日志

    最近在调试应用的时候发现了一个问题, 就是Xcode的控制台不打印Crash日志. 几经周折终于发现了问题.

    因为不能打印日志, 开始以为是我没有设置 NSSetUncaughtExceptionHandler 这个崩溃日志方法于是乎在appDelegate.m添加如下代码:

    void uncaughtExceptionHandler(NSException *exception) {
        NSLog(@"CRASH: %@", exception);
        NSLog(@"Stack Trace: %@", [exception callStackSymbols]);
        // Internal error reporting
    }
    
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {   
        NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);
        // Normal launch stuff
    }

    结果还是一样控制台还是只打印了这句话的错误信息: libc++abi.dylib: terminate_handler unexpectedly threw an exception 还是与事无补.

    于是继续寻找原因, 最终在每行代码块都注释的方式来排除问题,最终锁定了问题, 因为我引用了AvosCloud的后台SDK, 它默认开启了将崩溃日志上传的功能, 但是他没有打印本地的崩溃日志, 最后一段代码解决了这个问题.

    [AVAnalytics setCrashReportEnabled:NO];

    这里不得不得吐槽一下官方的教程, 换了类名但是教程还是没有及时更改, 害我找这个方法找了10分钟.
    [AVOSCloudCrashReporting enable];

    总结

    一般Xcode不输出Crash日志有一下几个可能:
    1. NSSetUncaughtExceptionHandler() 可能被重写了, 你调用之前它之后,(比如你引用了一些第三方库, 它的SDK里面可能包含了把Crash的日志上传到服务器, 这样这个日志可能被重写了, 就不打印本地的崩溃信息了) 尽量把它放在didFinishLaunchingWithOptions 最后面的一行代码块里.

    2. 还一种崩溃的情况是 EXC_BAD_ACCESS 当遇到这种错误, 控制一般不会给你很多关于崩溃的信息, 这种崩溃你只能使用下面这个调试方法, 不过记住你在正式发布的时候记得把这个勾取消, 不然会造成一些严重的问题(所有对象都不会被release,内存会一直涨).

    转自:南望青天的文章

    补充:我的项目之所以无法打印错误日志是因为使用了bugly崩溃日志管理SDK. bugly中有一个方法:

    • 日志输出控制

        开启/关闭 Bugly日志输出,默认关闭。建议release 时关闭

      - (void)enableLog:(BOOL)enabled;
    当此项设置为 NO时,工程中很多crash将没有提示信息,默认关闭.
  • 相关阅读:
    P2426 删数
    P2115 [USACO14MAR]破坏Sabotage
    P2679 子串
    P2979 [USACO10JAN]奶酪塔Cheese Towers
    P1114 “非常男女”计划
    P2105 K皇后
    P4053 [JSOI2007]建筑抢修
    P1294 高手去散步
    P4316 绿豆蛙的归宿
    P2253 好一个一中腰鼓!
  • 原文地址:https://www.cnblogs.com/shadowtree/p/4898519.html
Copyright © 2011-2022 走看看