《深入理解Android》一1.4 WebKit代码调试

简介:

本节书摘来自华章出版社《深入理解Android》一书中的第1章,第1.4节,作者孟德国 王耀龙 周金利 黎欢,更多章节内容可以访问云栖社区“华章计算机”公众号查看

1.4 WebKit代码调试

Android平台WebKit的调试分析的常用手段包括打印log、remote gdb调试以及分析crash dump等,下面分别介绍。
(1)打印log,将系统的运行信息输出到log系统
WebKit 代码量较大,很多逻辑非常复杂,单纯的断点调试,很难直观看到想要观察的数据。一方面对于一些嵌套非常强的逻辑,如递归等,使用断点调试很难直观看到相互关系。WebKit中一个典型的递归应用就是对Render树等树形结构的遍历,如果我们要打印出一棵Render树的各个节点,要直观地看到其结构,就需要使用log。另一方面WebKit中很多对象巨大,变量隐藏很深,可能有多个基类包含多次继承,并且还有智能指针的包裹,使得使用动态调试观看非常麻烦,所以传统的log打印对于我们来说仍然必要。在Android系统下,打印log函数是__android_log_print,其输出的log通过adb logcat查看。一般使用定义宏:

#define LOGD(...)  __android_log_print(ANDROID_LOG_DEBUG,LOG,__VA_ARGS__)
// 定义LOGD类型
#define LOGI(...)  __android_log_print(ANDROID_LOG_INFO,LOG,__VA_ARGS__)
// 定义LOGI类型
#define LOGW(...)  __android_log_print(ANDROID_LOG_WARN,LOG,__VA_ARGS__)
// 定义LOGW类型
#define LOGE(...)  __android_log_print(ANDROID_LOG_ERROR,LOG,__VA_ARGS__)
// 定义LOGE类型

在使用__android_log_print 前,先要在WebKit的Android.mk中加上liblog.so库的连接依赖,具体如下:

LOCAL_LDLIBS+= -L$(SYSROOT)/usr/lib -llog

(2)通过ndk-stack查看webkit native crash时导出的栈信息
当程序崩溃时,需要知道crash 发生在哪里,crash时函数的调用栈细节等信息。 Android程序崩溃时,会通过log系统输出crash时的寄存器和栈信息,部分机器会在/data/tombstones目录产生crash日志文件。将crash时产生的stack dump信息保存在crash.txt中,通过如下命令查看crash 时栈的dump信息:

ndk-stack -sym $SYMBOL_SO_PATH -dump crash.txt

SYMBOL_SO_PATH是符号库目录,在Android源码中是out/target/product/xx/symbol/system/lib。
 关于Android crash dump产生的原理可参考3.3节。
(3) 通过remote gdb直接动态调试运行中的浏览器
如果需要断点调试,单步跟踪,查看线程栈,此时就要使用gdb。Android源码本身提供脚本gdbclient连接设备上的gdbserver。将gdbserver push目标设备的特定目录(gdbserver可在Android源代码的prebuilt目录下找到,也可以从NDK中获取),赋予其可执行权限。在shell中启动设备上的gdbserver 并attach到browser线程:

$adb shell ps |grep com.android.browser #找到浏览器进程pid,需要先启动浏览器
$adb shell gdbserver :5039 --attach PID

其中5039为端口号,也可以自定义为其他端口。在另一个shell中启动端口映射:

$sudo adb forward tcp:5039 tcp:5039

启动gdbclient:

arm-eabi-gdb out/target/product/xx/symbols/system/bin/app_process

看到gdb的命令提示符“(gdb )”后,输入如下命令以载入符号库:

set solib-absolute-prefix out/target/product/xx/symbols/system/lib/
set solib-search-path out/target/product/xx/symbols/system/lib/
target remote:5039

等到各个lib加载完毕,就能看到gdb顺利启动起来,并再次显示命令提示符(gdb)。此后可以根据需要输入相应命令,比如设置断点:
b FrameLoaderClientAndroid.cpp:868
执行c,访问一个网址,就可以看到gdb断点了。此后就是我们熟悉的gdb命令了。

相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
1月前
|
Ubuntu 网络协议 Java
【Android平板编程】远程Ubuntu服务器code-server编程写代码
【Android平板编程】远程Ubuntu服务器code-server编程写代码
|
3月前
|
人工智能 IDE 开发工具
Studio Bot - 让 AI 帮我写 Android 代码
Studio Bot - 让 AI 帮我写 Android 代码
161 1
|
9月前
|
IDE 数据可视化 Java
Android自动生成代码,可视化脚手架之基础信息配置
今天的内容比较简单,大致过一下Electron一些基本用法,虽然说这些比较简单,但又是不得不去了解的,正如做Android的我们,也不是一上来就会的,需要一个循序渐进的过程,下一章,我们再去实际的开发功能。
135 0
|
2月前
|
Ubuntu 网络协议 Linux
【Linux】Android平板上远程连接Ubuntu服务器code-server进行代码开发
【Linux】Android平板上远程连接Ubuntu服务器code-server进行代码开发
57 0
|
3月前
|
安全 算法 JavaScript
安卓逆向 -- 关键代码定位与分析技术
安卓逆向 -- 关键代码定位与分析技术
42 0
|
3月前
|
安全 Android开发 数据安全/隐私保护
代码安全之代码混淆及加固(Android)
代码安全之代码混淆及加固(Android)
42 0
|
4月前
|
安全 Java Android开发
Android App开发之安全加固中反编译、代码混淆、第三方加固以及重签名的讲解及实战(图文解释 简单易懂)
Android App开发之安全加固中反编译、代码混淆、第三方加固以及重签名的讲解及实战(图文解释 简单易懂)
73 0
|
6月前
|
XML Java Android开发
Android 解决使用CocosCreator开发产品上架应用市场代码重复问题
Android 解决使用CocosCreator开发产品上架应用市场代码重复问题
278 0
|
7月前
|
JSON dexposed Java
一文总结 Android 隐私合规代码思路
一文总结 Android 隐私合规代码思路
|
7月前
|
SQL 程序员 Android开发
一行代码,利用 android studio自带的 liveTemplate 快速生成单例模式,程序员偷懒神器
一行代码,利用 android studio自带的 liveTemplate 快速生成单例模式,程序员偷懒神器