一. 概述
当发生ANR(Application Not Response),对于Java进程可通过kill -3向目标进程发送信号SIGNAL_QUIT, 输出相应的traces信息保存到目录/data/anr/traces.txt;而对于Native进程可通过 debuggerd输出traces信息。
可通过一条命令来获取指定Native进程的traces信息,例如输出pid=17529进程信息:
执行完该命令后直接输出traces信息到屏幕,如下:
接下来说说debuggerd是如何输出Native进程的trace。
二. Debuggerd
文章debuggerd守护进程详细介绍了Debuggerd的工作原理,此处当执行debuggerd -b命令后:
接下来,从dump_backtrace()方法讲起:
2.1 dump_backtrace
[-> debuggerd/backtrace.cpp]
2.2 dump_process_header
[-> debuggerd/backtrace.cpp]
例如:
2.3 dump_thread
[-> debuggerd/backtrace.cpp]
2.4 dump_backtrace_to_log
[-> debuggerd/Backtrace.cpp]
通过循环遍历输出整个backtrace中的每一栈帧FormatFrameData的信息.
2.5 FormatFrameData
[-> debuggerd/Backtrace.cpp]
例如:(这些map信息是由/proc/%d/maps解析出来的)
- #01 pc 000000000001cca4 /system/lib64/libc.so (epoll_pwait+32)
2.6 dump_process_footer
[-> debuggerd/backtrace.cpp]
- static void dump_process_footer(log_t* log, pid_t pid) {
- _LOG(log, logtype::BACKTRACE, "\n----- end %d -----\n", pid);
- }
例如:----- end 1789 -----
三. 总结
通过debuggerd -b [pid],可输出Native进程的调用栈,这些信息是通过解析/proc/[pid]/maps而来的。
【本文是专栏“小米开放平台”原创文章,“小米开放平台”微信公众号xiaomideveloper】
本文标题:Native进程之Trace原理
文章分享:http://www.mswzjz.cn/qtweb/news41/410741.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能