ios - 如何阅读这个 iOS 堆栈跟踪?
问题描述
我通常使用 Javascript 和 Python 等高级语言进行开发,因此在读取低级堆栈跟踪时我没有那么经验丰富。我正在使用 React Native 构建一个 iOS 应用程序,我的应用程序有时会意外崩溃。阅读崩溃日志这是我得到的:
Incident Identifier: B03D5F95-EFD1-4FEB-AE18-C8EFEF273E53
CrashReporter Key: 6049c1cc93a2e0163265631aa6cc2fd30a1af6e7
Hardware Model: iPhone7,2
Process: MyApp [24268]
Path: /private/var/containers/Bundle/Application/99B2B9A1-D266-4222-A083-84C4CFFCE182/MyApp.app/MyApp
Identifier: org.mycompany.MyApp
Version: 1 (1.0)
Code Type: ARM-64 (Native)
Role: Non UI
Parent Process: launchd [1]
Coalition: org.mycompany.MyApp [3119]
Date/Time: 2019-03-04 14:20:18.4924 +0800
Launch Time: 2019-03-04 14:09:15.2536 +0800
OS Version: iPhone OS 11.0.3 (15A432)
Baseband Version: 6.17.00
Report Version: 104
Exception Type: EXC_CRASH (SIGKILL)
Exception Codes: 0x0000000000000000, 0x0000000000000000
Exception Note: EXC_CORPSE_NOTIFY
Termination Reason: Namespace <0xF>, Code 0x8badf00d
Triggered by Thread: 0
Filtered syslog:
None found
Thread 0 name: Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0 libsystem_kernel.dylib 0x0000000180a60bc4 mach_msg_trap + 8
1 libsystem_kernel.dylib 0x0000000180a60a3c mach_msg + 72
2 BackBoardServices 0x00000001835d0de0 _BKSHIDGetCurrentDisplayBrightness + 112
3 BackBoardServices 0x00000001835de9cc BKSDisplayBrightnessGetCurrent + 32
4 FrontBoardServices 0x00000001835fffc0 -[FBSUIApplicationSystemService currentBacklightLevel] + 12
5 UIKit 0x000000018a8a3d44 -[UIDevice _backlightLevel] + 44
6 UIKit 0x000000018a8aced4 -[UIScreen _postBrightnessDidChangeNotificationIfAppropriate] + 168
7 CoreFoundation 0x0000000180efa12c __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__ + 20
8 CoreFoundation 0x0000000180efa090 ___CFXRegistrationPost_block_invoke + 64
9 CoreFoundation 0x0000000180f1016c __CFRUNLOOP_IS_CALLING_OUT_TO_A_BLOCK__ + 20
10 CoreFoundation 0x0000000180f0fa3c __CFRunLoopDoBlocks + 288
11 CoreFoundation 0x0000000180f0dca4 __CFRunLoopRun + 2436
12 CoreFoundation 0x0000000180e2e2d8 CFRunLoopRunSpecific + 436
13 GraphicsServices 0x0000000182cbff84 GSEventRunModal + 100
14 UIKit 0x000000018a3db880 UIApplicationMain + 208
15 MyApp 0x00000001005833d4 main + 29652 (main.m:14)
16 libdyld.dylib 0x000000018095256c start + 4
我如何/从哪里开始阅读 thsi 崩溃日志?我相信它与它有关,mach_msg_trap
但我无法找到任何关于它的东西。在某些情况下,我的应用程序是一个使用后台地理位置跟踪来跟踪用户地理位置的应用程序。我无法弄清楚导致崩溃的原因。
解决方案
请参阅TN2141:了解和分析应用程序崩溃报告,其中说:
异常代码
0x8badf00d
表示应用程序已被 iOS 终止,因为发生了看门狗超时。应用程序启动、终止或响应系统事件的时间过长。... 线程 0 上的任何操作都需要移至后台线程,或以不同方式处理,以免阻塞主线程。
您是否正在做任何可能长时间阻塞主线程的事情?
推荐阅读
- jquery - 将两种不同的 CSS 样式应用于两个不同的数据表?
- laravel-backpack - 如何在 Laravel-Backpack 中添加自定义 JavaScript
- struct - 如何以编程方式获取结构的字段数?
- laravel - 如何从laravel中的3个有条件的表中获取所有数据?
- android - 什么是更快的通信,直接在Android中发送广播VS调用活动方法?
- angular - 动画启动画面 - Ionic 4.0
- odbc - Tableau Linux 服务器,它是否无法识别用户 ODBC 设置
- python - python - 如何使用pandas更新而不是重写csv来获取股票数据?
- iis - Windows Server 2016 IIS 托管网站无法在阿里云上的远程文件共享上加载 dll
- mysql - JOIN 顺序和 WHERE