一些不容易复现的闪退,大众用户使用时的奔溃,对于只会使用xcode打印NSLog或者使用断点来调试的人来说,无疑是致命的bug。学会使用crash是,是程序进阶必经之路。
如何获取crash?
如果是能拿到运行崩溃过的iPhone
直接将手机连接电脑,打开xcode,点导航条上的Window->Devices 在打开的界面选中iPhone 点击 View Device Logs 里面有详细的信息,如同在Xcode中一样。
拿不到奔溃的iPhone手机,但能联系到使用人
把设备与电脑上的iTunes同步后,将崩溃日志保存在电脑上,然后邮件发给你。下图是MAC上的截图,crash一般使用项目名+时间+.crash命名。这样拿到的.crash是一堆通过编码后的十六进制地址(如图2),要通过解析才能看明白
同步后保存的位置
Mac:~/Library/Logs/CrashReporter/MobileDevice/
Windows XP: C:Documents and SettingsApplication DataApple ComputerLogsCrashReporterMobileDevice
Windows Vista or 7: C:UsersAppDataRoamingApple ComputerLogsCrashReporterMobileDevice
(图1)
(图2)
没法与用户交互
以上两种方法,比较适合在测试阶段。大众使用APP时崩溃基本上没办法联系到。这样的话,错误信息只能自己收集了。
苹果给我们提供了异常处理的类,NSException类,这个类可以创建一个异常对象,也可以通过这个类获取一个异常对象-(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler); }
void uncaughtExceptionHandler(NSException *exception) { NSLog(@"[Stack] >>> %@", [exception callStackSymbols]); /* 异常信息全在exception中,可以发邮件通知,也可以发请求写入服务端之后再读取 */ }
- 如果APP已经上架
开发者可以通过iTunes Connect 获取用户的crash日志。选择 Manage Your Applications,点击相应的应用,点击应用图标下面的View Details按钮,然后点击右侧Links部分的Crash Report