iOS.mach_msg_trap()
mach_msg_trap()
1. mach_msg() mach_msg_trap()
"
>
> 0 mach_msg_trap
> 1 mach_msg
> 2 CFRunLoopRunSpecific
> etc.
This is showing the main thread, which is just paused waiting for events. The crash is on a different thread,
but Xcode 3.1 often doesn't switch to the thread that crashed. You'll need to use the thread pop-up to
switch between the different threads to see which one actually has a crash. (Any other threads that are in
mach_msg_trap or in various functions having to do with locks or semaphores are also just idling.) " Ref[10]
2. What's trap?
"Mach system calls are commonly known as "traps", and are maintained in a Mach Trap table. " Ref[9]
3. System Trace
System Trace Profile vs. Time Profiler
"
You can use the System Trace tool in Instruments by running your App in profile mode.
Then you will get a detailed run down of all the threads in the system along with stack traces at each scheduling event the thread goes through.
There is a great video from the 2016 WWDC System Trace in Depth which will walk you through debugging a blocked thread issue.
This is much better than the Time Profiler instrument since, that tool works based off of taking samples of what is running on the CPU at intervals.
However, if your thread is blocked, it isn't running on the CPU, so - it will not be sampled. You might have your main thread blocked for
a whole second but it won't show up in Time Profiler.
" Ref[6]
"
System Trace Profiling Template
Instruments Included in Template
Points of Interest
System Load
Thread State Trace
Virtual memory Trace
System Call Trace
" Ref[7]
Reference
1. How can main thread be blocked in mach_msg_trap?
http://www.cocoabuilder.com/archive/cocoa/232843-how-can-main-thread-be-blocked-in-mach-msg-trap.html
2. kDebug
2.1 https://www.theiphonewiki.com/wiki/Kdebug
2.2 http://newosxbook.com/tools/kdv.html
2.3 https://www.slideshare.net/JohnPetrucci4/check-point-advanced-kernel-debug
3. Reaching the MACH layer
http://blog.wuntee.sexy/reaching-the-mach-layer
https://github.com/opensource-apple/xnu/
- Mach messages are sent via kernel traps.
4. mach_msg_trap
https://github.com/apple/darwin-xnu/blob/master/osfmk/mach/mach_traps.h
5. Mach Overview
https://developer.apple.com/library/content/documentation/Darwin/Conceptual/KernelProgramming/Mach/Mach.html#//apple_ref/doc/uid/TP30000905-CH209-TPXREF101
6. iOS How to determine what is blocking the UI
https://stackoverflow.com/questions/15928035/ios-how-to-determine-what-is-blocking-the-ui
7. System Trace Profiling Template
https://developer.apple.com/library/content/documentation/DeveloperTools/Conceptual/InstrumentsUserGuide/ProfilingTemplates.html#//apple_ref/doc/uid/TP40004652-CH19-SW1
8. macOS MACH Traps
https://sigsegv.pl/osx-mach-traps/
9. Kernel Syscalls
https://www.theiphonewiki.com/wiki/Kernel_Syscalls
10. help-with-debugger-mach-msg-trap-message
http://www.cocoabuilder.com/archive/xcode/279565-help-with-debugger-mach-msg-trap-message.html
11. Core Data Concurrency Debugging
https://oleb.net/blog/2014/06/core-data-concurrency-debugging/
You enable the assertions by passing -com.apple.CoreData.ConcurrencyDebug 1 to your app on the command line via Xcode’s Scheme Editor.
12. Technical Q&A QA1693 Synchronous Networking On The Main Thread
https://developer.apple.com/library/content/qa/qa1693/_index.html
13. System Trace in Depth
https://developer.apple.com/videos/play/wwdc2016/411/
iOS.mach_msg_trap()的更多相关文章
- iOS开发-应用崩溃日志揭秘(一)
作为一名应用开发者,你是否有过如下经历? 为确保你的应用正确无误,在将其提交到应用商店之前,你必定进行了大量的测试工作.它在你的设备上也运行得很好,但是,上了应用商店后,还是有用户抱怨会闪退 ! 如果 ...
- iOS测试常见崩溃
什么是崩溃日志,从哪里能得它? iOS设备上的应用闪退时,操作系统会生成一个崩溃报告,也叫崩溃日志,保存在设备上.崩溃日志上有很多有用的信息,包括应用是什么情况下闪退的.通常,上面有每个正在执行线程的 ...
- 【转】iOS应用崩溃日志分析
作为一名应用开发者,你是否有过如下经历? 为确保你的应用正确无误,在将其提交到应用商店之前,你必定进行了大量的测试工作.它在你的设备上也运行得很好,但是,上了应用商店后,还是有用户抱怨会闪退 ! ...
- iOS 深入理解RunLoop
RunLoop 是 iOS 和 OSX 开发中非常基础的一个概念,这篇文章将从 CFRunLoop 的源码入手,介绍 RunLoop 的概念以及底层实现原理.之后会介绍一下在 iOS 中,苹果是如何利 ...
- 苹果官方 Crash文件分析方法 (iOS系统Crash文件分析方法)
对于提交的苹果官方的app,在审核的时候会给我们一些crash文件,对于这些有用的文件,里面是关于我们的bug的一些信息,那么该如何去调试呢 第一步:在任意目录创建一个目录,用来调试crash,我这里 ...
- 【iOS程序启动与运转】- RunLoop个人小结
学习iOS开发一般都是从UI开始的,从只知道从IB拖控件,到知道怎么在方法里写代码,然后会显示什么样的视图,产生什么样的事件,等等.其实程序从启动开始,一直都是按照苹果封装好的代码运行着,暴露的一些属 ...
- 【转】iOS应用崩溃日志揭秘
这篇文章还可以在这里找到 英语 If you're new here, you may want to subscribe to my RSS feed or follow me on Twitter ...
- iOS 事件处理机制与图像渲染过程(转)
iOS 事件处理机制与图像渲染过程 iOS RunLoop都干了什么 iOS 为什么必须在主线程中操作UI 事件响应 CALayer CADisplayLink 和 NSTimer iOS 渲染过程 ...
- iOS开发之Crash分析,以及收集
一 先谈谈iOS的Crash收集方式: 1. APP 发生crash,用户手机手机上肯定会有crash纪录,当然删除了该app,或是删了再装 crash纪录还是没了. 2. 如果用户设置-隐私 同 ...
随机推荐
- nginx+ftp服务器搭建简易文件服务器
在做一些小项目和学习项目过程中,学习了通过 nginx 和 FTP 搭建小型文件服务器,记录下: 1.环境 电脑:acer 操作系统:windows 10 ftp服务器 2.下载 nginx, 通过双 ...
- IDEA tomcat8 控制台日志乱码
瞎扯一句:由于tomcat7之前编码默认都是GBK,tomcat8之后都是UTF-8 1.在idea64.exe.vmoptions(我装的是64位的)最后加入 -Dfile.encoding=UTF ...
- PackagesNotFoundError: The following packages are not available from current channels
因为要用到lifelines 包,在cmd中使用conda install lifelines ,显示如下错误: PackagesNotFoundError: The following packag ...
- ExcelPackage 读取、导出excel
private static string GetString(object obj) { try { return obj.ToString(); } catch (Exception ex) { ...
- (22/24) webpack实战技巧:静态资源集中输出
工作中会有一些已经存在但在项目中没有引用的图片资源或者其他静态资源(比如设计图.开发文档),这些静态资源有可能是文档,也有可能是一些额外的图片,而在打包时保留这些静态资源,直接打包到指定文件夹中.此时 ...
- sbt 学习
一.基础 1.工程根目录 包含build.sbt的目录是工程的根目录.注意,就算在一个空目录下面执行sbt about,也会生成project文件夹 2.源文件目录结构 SBT有固定的文件组织结构 s ...
- Linux 文本文件编辑命令
1.cat 查看纯文本文件,内容较少的,cat[选项][文件],显示行号的 -n 2.more 查看纯文本文件,内容较多的,more[选项]文件 3.head 查看纯文本文档的前N行,head -n ...
- mysql安装密码策略插件
https://blog.csdn.net/kk185800961/article/details/79447754 注意linux安装密码策略的插件 validate_password.so
- reg 和wire 区别
reg相当于存储单元,wire相当于物理连线 Verilog 中变量的物理数据分为线型和寄存器型.这两种类型的变量在定义时要设置位宽,缺省为1位.变量的每一位可以是0,1,X,Z.其中x代表一个未被预 ...
- 一文读懂PRBS定义、生成办法、作用
对于眼图测试.误码率和抖动容限测试,最常用的测试码是PRBS,主要有PRBS7.PRBS15.PRBS23和PRBS31.本文主要解释了PRBS的定义,生成方法以及简单应用. PRBS定义 二进制序列 ...