一、crash log的获取
我们要获取的就是设备中的这个CrashLog。 1、获取用户的 crash log
作为开发者,你想要获取到你的用户的崩溃日志的话就得通过 iTunes Connect 了。在 iTunes Connect 上的 Manage Your Applications -> View Details -> Crash Reports
2、获取测试机的crash log很多测试人员在测试途中,或者开发者在自测的途中,会遇到APP crash的情况。 一般的bug,一个合格的测试可以给出明确的重现步骤让开发者清晰地知道bug原因; 也有不少bug,很多时候是偶现的,很可能无法再次重现出来,无法重现出来的bug是开发者头疼的,测试一般会给出bug的截图和重现步骤; 而一般crash是比较严重的问题了(所以千万不能当什么都没发生过,不然会被打的233),这个时候崩溃日志就尤为重要了,把崩溃日志send给开发人员,如此才能让开发者快速定位到错误的原因和位置。 那么测试如何拿到crash日志呢?
iOS崩溃日志分析_itools.png
Mac : ~/Library/Logs/CrashReporter/MobileDevice/<DEVICE_NAME>
Windows : C://Users/<USERNAME>/AppDataRoamingApple/ComputerLogsCrashReporterMobileDevice/<DEVICE_NAME>/
iOS崩溃日志分析_finder.png
iOS崩溃日志分析_devices(1).png
二、Crash Log的符号化获取到了.crash或者.ips文件的时候(憋纠结这两个文件有什么差,改下后缀名就ok),用文本编辑器打开文件是一堆十六进制的内存地址,你会郁闷的发现压根看不懂。
log(脱敏后有点丑).png
A:当然,将这些十六进制地址转化成方法名称和行数的过程称之为Symbolication(符号化)。符号化很简单,只要你把你的.crash文件拉到上面提到过的Xcode的device log里面,然后几秒钟后就会符号化。但是这里有个前提,就是这个发生crash的版本包必须是你自己的Xcode里面Archive出来的(这个是苹果自带的方法,会自动检测是否含有匹配的.dSYM文件和应用二进制文件)。
答案是,只有相匹配的.dSYM文件和应用二进制文件就可以符号化。必需完全匹配才行。否则,日志将无法被完全符号化。
.dSYM文件位置在编的.xcarchive的包内容里面
灰色的都是app的名字
三、Crash Log的分析
接下来就让我们对已经符号化以后的crash文件进行分析。 Incident Identifier: F3573A...E2F244A //crash的id CrashReporter Key: cc2298...es77eeb //crash的设备id Hardware Model: iPhone7,2 //手机型号 Process: [AppName] [1816] //APP的名字[进程的id] Path: /private/.../Application... //APP的位置 Identifier: com.... //bundle ID Version: 14 (2.3.5) //版本号 Code Type: ARM-64 (Native) //app的应用架构之类不大清楚,^_^ Parent Process: launchd [1] Date/Time: 2015-10-26 15:03:29.29 +0800 //crash发生时间 Launch Time: 2015-10-26 14:58:28.28 +0800 //进入应用时间 OS Version: iOS 9.1 (13B143) //iOS版本 Report Version: 105 当你有大量的crash文件的时候,你就可以对crash文件里面的 Hardware Model,Version , OS Version等进行分类,就可以获知到很多信息,比如说,你会知道crash一般发生原因是因为手机型号,还是App版本,或者还是手机版本的原因。(笔者暂时没碰过大量的crash文件,所以只能纸上谈兵了^_^) 2、其次是异常信息 Exception Type: EXC_BAD_ACCESS (SIGABRT) //异常的类型 Exception Subtype: KERN_INVALID_ADDRESS at 0x0000000000000118 //异常子类型 Triggered by Thread: 0 //异常发生的线程(0为主线程,其他为子线程) 3、线程信息 Last Exception Backtrace: 0 CoreFoundation 0x182780f48 __exceptionPreprocess + 124 1 libobjc.A.dylib 0x197333f80 objc_exception_throw + 56 2 CoreFoundation 0x182780e90 +[NSException raise:format:] + 120 3 [AppName] 0x100c42a40 UmengSignalHandler + 144 4 libsystem_platform.dylib 0x197d6193c _sigtramp + 52 5 [AppName] 0x1005d9f38 CScopePtr<IAVGAudioLogic>::operator IAVGAudioLogic*<IAVGAudioLogic>() (xprefc.h:165) 6 [AppName] 0x1005d3b8c tencent::av::AVRoomMultiImpl::GetAudioLogic() (av_room_multi_impl.h:119) 7 [AppName] 0x10057076c tencent::av::AVAudioCtrlImpl::SetAudioOutputMode(int) (av_audio_ctrl_impl.cpp:443) 8 [AppName] 0x10044dc3c -[AVBasicManager changeSpeakerMode:] (AVManager.mm:525) 9 [AppName] 0x100296e1c -[KTQAVRoom enableSpeakerMode:] (KTQAVRoom.m:345) 10 [AppName] 0x1002970d0 -[KTQAVRoom settingSpeaker:] (KTQAVRoom.m:362) 11 [AppName] 0x1003d5464 -[KTChatView onAudioNotificationReceived:] (KTChatView.m:685) 恩。。。这符号化以后应该可以看懂了吧,这个crash的问题应该是腾讯第三方的一个冲突吧233 一般来说,通过异常信息和线程信息就可以找到crash的原因了。 补充一些异常类型信息
1、Exception Type1)EXC_BAD_ACCESS
SIGSEGV: 通常由于重复释放对象导致,这种类型在切换了ARC以后应该已经很少见到了。 2)EXC_BAD_INSTRUCTION
3)EXC_ARITHMETIC
2、Exception Code
0xbaaaaaad 此种类型的log意味着该Crash log并非一个真正的Crash,它仅仅只是包含了整个系统某一时刻的运行状态。通常可以通过同时按Home键和音量键,可能由于用户不小心触发 |