Android 调试技巧

作为一名码农,代码调试是一项不可或缺的工作,过程中总能发现一下能提高效率、有用的小技巧,此文特总结一些工作用到的一些调试技巧。

Debug技巧

断点debug大家都会使用,但除了单步调试之外,用过条件断点,日志断点么,一些很有用的debug技巧或许你不知道。。

  • 临时断点

顾名思义,临时性断点,在第一次触发后会自动被移除

临时断点

触发键:Alt + 鼠标左键

  • 禁用断点

当你需要临时禁用一些断点,但不想下一次再重新创建这些断点的时候有用

禁用断点

触发键:Alt + 鼠标左键

  • 计算表达式

当你需要临时改变某个变量的值或者查看其内部方法返回值时很有用

计算表达式

触发键:Alt + F8

  • 计算表达式

当你需要临时改变某个变量的值或者查看其内部方法返回值时很有用

计算表达式

触发键:Alt + F8

  • 检查表达式

不需要打开表达式计算框就可以看到计算结果

检查表达式

触发键: 选中表达式,Alt + 鼠标左键

  • 条件断点

在特定条件下才断点

条件断点

触发键:鼠标右键点击断点

  • 日志断点

厌倦了每次输出一个log都得重新发布项目?试试日志断点,无痛解决你的问题

日志断点

触发键:鼠标右键点击断点后–>more–>勾掉suspend 属性(应用不挂起)–>填上想要输出的日志信息

ADB技巧

adb作为android开发一个常用的工具,神马install,uninstall,push,pull命令就不用说了,它还有很多有用命令。。

  • 删除文件夹及其下面所有文件
1
adb shell rm -r /sdcard/xx/
  • 应用程序恢复初始状态:清除数据
1
adb shell pm clear com.xx.xx(包名)
  • 测试软件的稳定性、健壮
1
adb shell monkey --ignore-crashes --ignore-timeouts --ignore-security-exceptions --monitor-native-crashes --ignore-native-crashes -s 100 -v -v --throttle 100 -p com.xx.xx(包名) 10000 > ~/Downloads/monkey_test.txt
  • 获取设备分辨率
1
2
3
adb shell wm size
或者
adb shell dumpsys display | grep DisplayDeviceInfo

adb shell dumpsys: 个人觉得是最有用的adb命令,默认打印出当前系统所有service信息,在后面可加上具体的服务名。 需要列出当前运行的服务,可运行: adb shell dumpsys | grep DUMP

  • 获取内存信息
1
adb shell dumpsys meminfo
  • 要获取具体应用的内存信息,可加上包名
1
adb shell dumpsys meminfo com.xx.xx

通常来说: Heap Free > Pss Total > Private Dirty

具体参数说明,可以参考 官方文档

  • 列出系统所有属性
1
2
3
4
5
adb shell getprop
> 获取分辨率密度:adb shell getprop |grep ro.sf.lcd_density
> 获取系统版本: adb shell getprop |grep ro.build.version.release
  • 查看Activity任务栈
1
adb shell dumpsys activity activities | sed -En -e '/Running activities/,/Run #0/p'
  • 启动默认浏览器打开一个网页
1
adb shell am start -a android.intent.action.VIEW -d http://baidu.com

网络调试技巧

日常开发中,不可避免的需要联网操作,这可能就需要懂一些网络调试技巧了,而抓包就是最基本的网络调试技巧。。

HTTP或HTTPS抓包( finddler(windows)/charles)

这个就不多说了,网上教程一大堆。。

charles使用教程

finddler使用教程

TCP非实时抓包(tcpdump)

前提:Root

  1. 这里 下载 tcpdump

  2. 将 tcpdump 放入手机: adb push ~/tcpdump /data/local/tcpdump

  3. 将 tcpdump 的权限变为可执行:chmod +x tcpdump

  4. 开始抓包:

    /data/local/tcpdump -vv -s 0 -w /mnt/sdcard/pcapture.pcap。其中 “-s 0” 表示每个包都抓取全部长度,而不是部分长度;”-w /mnt/sdcard/pcapture.pcap” 表示抓取的包写入指定文件;”-vv” 表示显示多一些信息,如果要显示更多信息可以用 “-vvv”

  5. 按下 “contrl+c” 结束抓包。

  6. 将”/mnt/sdcard/pcapture.pcap” 移到电脑上: adb pull /mnt/sdcard/pcapture.pcap <指定目录>

  7. 通过 Wireshark 或者charles进行分析。

TCP实时抓包(wireshark+tcpdump)

参考文章

基本思路:

基本思路

  • 手机开始抓包:在 adb shell 中运行 /data/local/tcpdump -n -s 0 -w - | nc -l -p 12345

  • 将手机抓的包传送到电脑的 Wireshark 中:另开一个终端运行 adb forward tcp:12345 tcp:12345 && nc 127.0.0.1 12345 | /Applications/Wireshark.app/Contents/MacOS/wireshark -k -S -i -

Adison wechat
欢迎您扫一扫上面的微信公众号,订阅我的博客!