哪个库导致此崩溃?

时间:2015-09-08 08:38:12

标签: ios crash

我有一个象征性的堆栈跟踪让我头疼!令人讨厌的是,我无法在任何测试设备上重现这一点,因此我只能使用崩溃报告。

Application Specific Information:
*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'Invalid type in JSON write (NSURLResponseInternal)'

Last Exception Backtrace: CoreFoundation                 
0x2ac7af8f __exceptionPreprocess + 126 libobjc.A.dylib                
0x3932bc8b objc_exception_throw + 38 CoreFoundation                 
0x2ac7aed5 -[NSException initWithCoder:] + 0 Foundation                     
0x2ba218d1 0x2b8ef000 + 632 Foundation                     
0x2ba23463 ___writeJSONObject_block_invoke + 186 CoreFoundation                 
0x2ab96f5d __65-[__NSDictionaryM enumerateKeysAndObjectsWithOptions:usingBlock:]_block_invoke + 92 CoreFoundation                 
0x2ab96e7f -[__NSDictionaryM enumerateKeysAndObjectsWithOptions:usingBlock:] + 174 Foundation       
0x2ba230e3 _writeJSONObject + 414 Foundation                     
0x2ba2180f _writeJSONValue + 438 Foundation                     
0x2ba21625 -[_NSJSONWriter dataWithRootObject:options:error:] + 128 Foundation                     
0x2ba224bf +[NSJSONSerialization dataWithJSONObject:options:error:] + 338 whats-new                     
0x00315fa3    0xc9000 (WNLoadingView.m:28) whats-new                   
0x00318683    0xc9000 (WNLoadingView.m:28) whats-new                   
0x003199fb    0xc9000 (WNLoadingView.m:28) libdispatch.dylib           
0x398bc2cf _dispatch_client_callout + 22 libdispatch.dylib             
0x398c3a3d _dispatch_barrier_sync_f_invoke + 48 whats-new              
0x00319911    0xc9000 (WNLoadingView.m:28) whats-new                   
0x003185bb    0xc9000 (WNLoadingView.m:28) whats-new                   
0x0031fac3    0xc9000 (WNLoadingView.m:28) whats-new                   
0x0031f97f    0xc9000 (WNLoadingView.m:28) whats-new                   
0x0031dce3    0xc9000 (WNLoadingView.m:28) libdispatch.dylib           
0x398bc2e3 _dispatch_call_block_and_release + 10 libdispatch.dylib     
0x398c3dff _dispatch_after_timer_callback + 66 libdispatch.dylib       
0x398ce173 _dispatch_source_latch_and_call + 1606 libdispatch.dylib    
0x398bde15 _dispatch_source_invoke + 212 libdispatch.dylib             
0x398c4397 _dispatch_queue_drain + 554 libdispatch.dylib              
0x398beaad _dispatch_queue_invoke + 84 libdispatch.dylib              
0x398c5f9f _dispatch_root_queue_drain + 394 libdispatch.dylib          
0x398c73c3 _dispatch_worker_thread3 + 94 libsystem_pthread.dylib       
0x39a20db5 _pthread_wqthread + 668 libsystem_pthread.dylib        
0x39a20b08 start_wqthread + 8

崩溃的原因非常明显(并不是我的问题!) - 我试图将一个非jsonable对象写入json数据。棘手的部分是确切地解决这个问题。

WNLoadingView.m的所有引用都是完整的红色鲱鱼 - WNLoadingView的行只是@implementation WNLoadingView而地址0xc9000只是我们二进制文件的起点记忆。但是,0x00315fa3看起来像是在我们的空间,但我不知道如何看到实际存在的内容:)

叹息。

我目前的理论是崩溃发生在我没有调试信息的库中(即从一个pod链接的第三方.a)。

我想我有两个问题;

如何使用此堆栈跟踪找出导致此问题的库?

如果我的理论不正确,有没有人知道另一种尝试或有其他理论的方法?

1 个答案:

答案 0 :(得分:1)

您可以采取以下几种途径:

  1. 让自己成为一个完全符号化的崩溃日志。我发现this post非常有用,特别是安德烈亚斯的回答(不幸的是,这不是公认的答案)。如果你可以使用它,你可能不需要任何其他东西。
  2. 使用二进制文件的链接映射来确定相关地址(0x00315fa3)所在的位置。如果您没有设置构建以提前为应用程序商店(甚至更旧版本)上的应用程序版本生成链接映射,则这可能无法解决,但是您很可能<通过在您最初用于构建应用程序的版本控制系统中的同一提交点(YMM GREATLY V)从头开始重建应用程序,可能进入大球场。无论您是否已经设置或需要设置您的构建以生成一个,您将需要一个前进;阅读the second post的第一部分,了解有关在Xcode中设置构建以生成链接映射的说明,以及在生成链接映射后在何处查找它。如果您使用命令行工具构建应用程序以进行提交,则需要挖掘相关的开关(您可以使用Xcode构建更改来确定它的作用并在构建脚本/命令中使用它) 。链接映射非常有用,因为它可以告诉您所有应用程序源代码中的文件/方法,包括第三方库,即使您没有它们的源代码(它是整个应用程序的完整地图,而不是只是你的代码);您仍然可以获得有关直接导致崩溃的整体呼叫流程的有用提示。
  3. 虽然the second post的目的不能直接解决您的问题(并且坦率地说您的具体问题有些过分),但许多关于如何阅读链接地图的想法以及您可以用来自动化某些工具的工具任务应该让您充分了解如何收集相关信息。具体来说,您需要找到其地址范围包含相关地址(0x00315fa3)的文件/方法调用,如果一切顺利(意味着您有准确的地图),则该信息应该指出你有权使用违规的图书馆,文件和方法。