【问题标题】:Which library is causing this crash?哪个库导致了这个崩溃?
【发布时间】:2015-09-08 08:38:12
【问题描述】:

我有一个符号化的堆栈跟踪,这让我很头疼!烦人的是,我无法在我们的任何测试设备上重现这一点,所以我只能使用崩溃报告。

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 链接的第 3 方 .a)。

我想我有两个问题;

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

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

【问题讨论】:

  • 为了更好地理解您的问题,您能回答我的问题吗?让我说崩溃发生在某个苹果的库中,例如NSJSONSerializationLib在这种情况下你会怎么做?
  • @sage444 Apple 库引发了异常,但由于我的应用程序传入的输入数据无效。如果我能找出我在应用程序中传递导致崩溃的数据的位置,我可以在那里修复它(或者至少在它周围放置一个 try/catch 并恢复)。
  • 好的,现在我看到这个日志没有完全符号化并且只指向一个文件WNLoadingView,而不是确切的行/方法。还不够开始吗?
  • 也看看dispatch_after 我相信这不是经常使用的,可以指出你在代码中的确切位置
  • @sage444 我在我的应用程序中搜索了dispatch_afterdataWithJSONObject,但如果它发生在第3 方预编译库中,我将无法看到它。对 dataWithJSONObject 的调用看起来都很正常 :)

标签: ios crash


【解决方案1】:

您可能会寻求以下几种途径:

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

【讨论】:

  • 嗨 - (1) 不起作用,因为我没有库的调试符号,所以我无法制作更完整的 dSYM。叹。 (2) 结合链接中的说明制作链接器映射,让我在我没有调试信息的偏移量处查找二进制文件中的内容。它们都在一个库中,所以我很确定我现在知道罪魁祸首——与他们一起写支持票的时间。 . . . :)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多