Android 调试工具及方法(二)

设备上调试和测试的设置

Android提供了众多的设置使你可以更容易的调试和测试程序.要进入开发设置页面,在模拟器中转到DevTools>DevelopmentSettings.在该设置页面有以下选项:

Debugapp:选择要调试的程序.你不需要设定其关联至调试器,但是设定这个值有两个效果:

在调试的时候,如果你在一个断点处暂停了过长的时间,这个设定会防止Android抛出一个错误

这个设定使你可以选择“等待调试器”选项,使程序只有在调试器关联上之后才启动

WaitforDebugger:阻塞所选的程序的加载直到有调试器关联上,这样你就可以在onCreate()中设置断点,这对于调试一个Activity的启动进程是非常重要的.当你对该选项进行了更改,任何正在运行的程序的实例都会被终止.你只有在上面的选项中选择了一个调试程序才能够选中该选项.你也可以在代码中添加waitForDebugger()来实现同样的功能.

Immediatelydestroyactivities:告诉系统一旦一个activity停止了就销毁该activity(例如当Android释放内存的时候).这对于测试代码onFreeze(Bundle)/onCreate(android.os.Bundle)是非常有用的,否则会比较困难.如果你的程序没有保存状态,那么选择这个选项很可能会引发很多问题.

Showscreenupdates:对于任何正在被重绘的screensections都会在其上闪现一个粉红色的矩形.这对于发现不必要的screen绘制是很有必要的.

ShowCPUusage:在屏幕上方显示CPU信息,显示有多少CPU资源正在被使用.上方红色条显示总的CPU使用率,它下方绿色的条显示CPU用在compositingthescreen上的时间.注意:在没有重启模拟器之前,一旦你开启了该功能就不能关闭.

ShowscreenFPS:显示当前的帧率.这对于查看游戏达到的总的帧率是非常有用的.注意:在没有重启模拟器之前,一旦你开启了该功能就不能关闭.

Showbackground:当没有activityscreens可见时,显示一个背景模式.一般是不会出现的,仅仅在Debug的时候会出现.

设定的选项在模拟器重启之后仍然有效,如果要取消设定的选项,在取消设定以后还要重启模拟器,才能生效.

重要的调试小提示

快速的堆栈dump

要在模拟器上获得一个堆栈dump,你可以通过adbshell登入,用“ps”找到你想要的进程,然后“kill-3”,

堆栈跟踪信息就会记录到日志文件中了.

在模拟器屏幕上显示有用信息

设备上可以显示诸如CPU利用率或者对重绘区域的边缘高亮显示等有用信息,在开发设置窗口可以打开或者关闭这些功能.

从模拟器上获取系统状态信息(dumpstate)

你可以通过DalvikDebugMonitorService工具来获得dumpstate信息.

从模拟器上获取程序状态信息(dumpsys)

你可以通过DalvikDebugMonitorService工具来获得dumpsys信息.

获取无线连接信息

你可以通过DalvikDebugMonitorService工具来获得无线连接信息.在Device菜单,选择“Dumpradiostate”

日志记录跟踪数据

你可以在一个activity中通过调用android.os.Debug.startMethodTracing()来用日志来记录方法调用和其他跟踪数据.

日志记录RadioData

默认情况下,radio信息是不会记录在系统中的(因为数据量巨大).然而,你可以通过下面的命令来开启radio记录

adbshell

logcat-bradio

运行adb

Andoid中自带了一个叫adb的工具,该工具功能强大,可以移动并同步文件到模拟器,转发端口.在模拟器上运行一个UNIXshell.

从模拟器上获取屏幕截图

DalvikDebugMonitorServer(DDMS)可以从模拟器上获取屏幕截图

利用调试帮助类

Android为了开发者的方便提供了诸如util.Log和Debug等帮助类

相关推荐