iOS 友盟崩溃日志分析——Backtraces

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: iOS 友盟崩溃日志分析——Backtraces

崩溃进程的每个线程都被捕获为回溯,记录进程终止时线程上运行的代码。回溯与使用调试器暂停进程时看到的类似。由语言异常引起的崩溃包括位于第一个线程之前的附加回溯,即最后一个异常回溯。


友盟崩溃日志原文:

Thread 0 Crashed:
0   libobjc.A.dylib                     0x00000001cd9cae20 objc_retain + [ : 16] 
1   XXXApp                              0x0000000103042080 ReachabilityCallback + [ : 40] 
2   SystemConfiguration                 0x00000001de6076c4 reachPerformAndUnlock + [ : 620] 
3   CoreFoundation                      0x00000001d46e622c __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + [ : 28] 
4   CoreFoundation                      0x00000001d46f2614 __CFRunLoopDoSource0 + [ : 176] 
5   CoreFoundation                      0x00000001d467657c __CFRunLoopDoSources0 + [ : 340] 
6   CoreFoundation                      0x00000001d468beb8 __CFRunLoopRun + [ : 836] 
7   CoreFoundation                      0x00000001d46911e4 CFRunLoopRunSpecific + [ : 612] 
8   GraphicsServices                    0x000000020d4b1368 GSEventRunModal + [ : 164] 
9   UIKitCore                           0x00000001d6b40d88 -[UIApplication _run] + [ : 888] 
10  UIKitCore                           0x00000001d6b409ec UIApplicationMain + [ : 340] 
11  XXXApp                              0x0000000102470efc main + [main.m : 16] 
12  (null) 0x00000001f29b5948 0x0 + 8365234504
Thread 1 name:  JavaScriptCore libpas scavenger
Thread 1:
0   libsystem_kernel.dylib              0x0000000210cfc41c __psynch_cvwait + [ : 8] 
1   libsystem_pthread.dylib             0x0000000220f4006c _pthread_cond_wait + [ : 1232] 
2   JavaScriptCore                      0x00000001e7a03c70 0x1e7910000 + 998512
3   libsystem_pthread.dylib             0x0000000220f396cc _pthread_start + [ : 148] 
Thread 2:
0   libsystem_kernel.dylib              0x0000000210cfc050 __workq_kernreturn + [ : 8] 
1   libsystem_pthread.dylib             0x0000000220f38e44 _pthread_wqthread + [ : 364]


分析:

每个回溯的第一行列出线程编号和线程名称。出于隐私考虑,通过Xcode中的崩溃管理器提交的崩溃报告不包含线程名称。此示例显示了三个线程的回溯;线程0崩溃,并通过其名称标识为应用程序的主线程。

在线程号之后,回溯的每一行表示回溯中的堆栈帧。

0   libobjc.A.dylib                     0x00000001cd9cae20 objc_retain + [ : 16]


堆栈帧的每一列都包含有关崩溃时执行的代码的信息。下面的列表使用了上面示例中堆栈帧0的组件。

  • 0  堆栈帧编号。堆栈帧按调用顺序排列,其中帧0是执行停止时正在执行的函数。帧1是调用帧0中的函数的函数,依此类推。
  • libobjc.A.dylib  包含正在执行的函数的二进制文件的名称。
  • 0x00000001cd9cae20  正在执行的机器指令的地址。对于每个回溯中的帧0,这是进程终止时线程上执行的机器指令的地址。对于其他堆栈帧,这是在控制返回到该堆栈帧之后执行的第一条机器指令的地址。
  • objc_retain  在完全符号化的崩溃报告中,是正在执行的函数的名称。出于隐私考虑,函数名有时仅限于前100个字符。
  • [ : 16]   +后面的数字是从函数的入口点到函数中当前指令的字节偏移量。
    如果二进制文件有dSYM文件,则包含代码的文件名和行号。

在某些情况下,文件名或行号信息与原始源代码不符:

  • 如果源文件名为<compiler generated>,则编译器为该帧创建了代码,而代码不在源文件中。如果这是崩溃线程中的顶部帧,请查看前面的几个堆栈帧以获取线索。
  • 如果源文件的行号为0,这意味着回溯不会映射到原始代码中的特定代码行。这是因为编译器优化了代码,例如通过内联函数,并且在崩溃时执行的代码与原始代码中的一行不一致。在这种情况下,框架的函数名仍然是一个线索。


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
3月前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
331 4
|
3月前
|
安全 Android开发 数据安全/隐私保护
深入探讨iOS与Android系统安全性对比分析
在移动操作系统领域,iOS和Android无疑是两大巨头。本文从技术角度出发,对这两个系统的架构、安全机制以及用户隐私保护等方面进行了详细的比较分析。通过深入探讨,我们旨在揭示两个系统在安全性方面的差异,并为用户提供一些实用的安全建议。
|
19天前
|
机器学习/深度学习 人工智能 运维
智能日志分析:用AI点亮运维的未来
智能日志分析:用AI点亮运维的未来
140 15
|
1月前
|
SQL 关系型数据库 MySQL
MySQL事务日志-Undo Log工作原理分析
事务的持久性是交由Redo Log来保证,原子性则是交由Undo Log来保证。如果事务中的SQL执行到一半出现错误,需要把前面已经执行过的SQL撤销以达到原子性的目的,这个过程也叫做"回滚",所以Undo Log也叫回滚日志。
MySQL事务日志-Undo Log工作原理分析
|
2月前
|
存储 运维 监控
Linux--深入理与解linux文件系统与日志文件分析
深入理解 Linux 文件系统和日志文件分析,对于系统管理员和运维工程师来说至关重要。文件系统管理涉及到文件的组织、存储和检索,而日志文件则记录了系统和应用的运行状态,是排查故障和维护系统的重要依据。通过掌握文件系统和日志文件的管理和分析技能,可以有效提升系统的稳定性和安全性。
57 7
|
2月前
|
监控 安全 Linux
启用Linux防火墙日志记录和分析功能
为iptables启用日志记录对于监控进出流量至关重要
|
3月前
|
安全 Android开发 数据安全/隐私保护
深入探索Android与iOS系统安全性的对比分析
在当今数字化时代,移动操作系统的安全已成为用户和开发者共同关注的重点。本文旨在通过比较Android与iOS两大主流操作系统在安全性方面的差异,揭示两者在设计理念、权限管理、应用审核机制等方面的不同之处。我们将探讨这些差异如何影响用户的安全体验以及可能带来的风险。
113 21
|
2月前
|
Java 开发工具 Android开发
安卓与iOS开发环境对比分析
在移动应用开发的广阔天地中,安卓和iOS两大平台各自占据半壁江山。本文深入探讨了这两个平台的开发环境,从编程语言、开发工具到用户界面设计等多个角度进行比较。通过实际案例分析和代码示例,我们旨在为开发者提供一个清晰的指南,帮助他们根据项目需求和个人偏好做出明智的选择。无论你是初涉移动开发领域的新手,还是寻求跨平台解决方案的资深开发者,这篇文章都将为你提供宝贵的信息和启示。
42 8
|
2月前
|
监控 应用服务中间件 定位技术
要统计Nginx的客户端IP,可以通过分析Nginx的访问日志文件来实现
要统计Nginx的客户端IP,可以通过分析Nginx的访问日志文件来实现
203 3
|
3月前
|
存储 SQL 监控

热门文章

最新文章