概述
创造愉快用户体验的关键是开发响应快捷的应用。借助Android* 软件开发套件(SDK)提供的组件,性能问题调试任务因为简单易用的性能分析工具而变得更简单了。在这篇文章中,我们将认识一些不同的工具,它们可排除故 障和调试性能问题或小幅度提升已完成应用的性能。我们不会说得太细,只会概括介绍如何针对您的应用使用这些工具。我们将在Eclipse 中展示这些工具;您可以根据“ADT Plugin for Eclipse* (面向 Eclipse 的 ADT 插件)”一文中的说明来安装ADT插件。
DDMS
DDMS是一款Google* 提供的应用,可作为独立的工具运行,也可通过ADT Eclipse* 插件集成到Eclipse* 中。它提供了强大的特性集合,能帮助您快速了解应用的运行状况。
线程更新
DDMS中的线程监控和评测浏览对于管理大量线程的应用很有用。要启用,点击 Update Threads(更新线程)图标即可开始。
堆工具
堆查看点击Update Heap(更新堆)按钮,获得有关选定虚拟机中堆分配的信息。
上例可简单重构为下面的代码,节省构造临时char[]的开销。.dataStrBuilder.append(String.format(" Std. Dev.: %.3f, %.3f, %.3f\n", devX, devY, devZ));
Method Profiling(方法分析)
Method Profiling(方法分析)是DDMS的一款工具,对于快速概览应用中时间的消耗分布非常有用,也可用于时间关键型函数的详细查看。
分析API
为获得有着更高精度的的方法分析细节,调用可在代码中进行以启动和停止分析。您需要在设备中加载一个SD卡来使用此方法。在下面的例子中,我们添加hook(钩子)以更好地了解传感器处理代码:
01
private
static
boolean doOnce =
true
;
02
03
@Override
04
public
void
onSensorChanged(SensorEvent event) {
05
06
if
( doOnce ) {
07
android.os.Debug.startMethodTracing();
08
}
09
10
Code under test…
11
12
if
( doOnce ){
13
android.os.Debug.stopMethodTracing();
14
doOnce =
false
;
15
}
16
}
跟踪文件默认为:/ mnt / sdcard/dmtrace.trace,可通过下面的命令从设备中提取出来:adb pull /mnt/sdcard/dmtrace.trace.
运行独立的Traceview工具:“traceview C:\dmtrace.trace”,会打开一个用户界面,类似于嵌入到Eclipse中的用户界面。
布局用户界面工具
layoutopt(布局选择)每当要调用某应用结束时,我就希望在活动的用户界面布局中获得简单的性能增益。 layoutopt这一工具会分析您的布局文件,并指出潜在的性能问题。在这篇博客和参考文件会谈到该问题,让我们快速浏览该如何使用这一工具吧。命令行用法如下:layoutopt.bat C:\Projects\workspace\DeviceInformation\res
注:我把Android* SDK工具目录放在我的路径中。它看起来也像一款工具,只在您详细说明要分析目录的完整路径时才可用。输出示例:
C:\Projects\workspace\DeviceInformation\res\drawable\btn_notification_ic_example.xmlC:\Projects\workspace\DeviceInformation\res\drawable\picture_frame.xmlC:\Projects\workspace\DeviceInformation\res\layout\action_bar_custom.xml23:23 This TextView layout or its LinearLayout parent is uselessC:\Projects\workspace\DeviceInformation\res\layout\content_applicationinfo_main.xml16:19 This LinearLayout layout or its LinearLayout parent is uselessC:\Projects\workspace\DeviceInformation\res\layout\content_benchmark_main.xmlC:\Projects\workspace\DeviceInformation\res\layout\content_main.xmlC:\Projects\workspace\DeviceInformation\res\layout\content_sensorinfo_main.xml17:20 This LinearLayout layout or its LinearLayout parent is useless
X:Y是与问题对应的XML标记的开始行和结束行。上面指出的多余布局增加了活动的整体加载时间,可用于方便地提升您的活动加载速度。
Hierarchy Viewer(层级查看器)
性能问题调试中另一款有用工具就是Hierarchy Viewer (层级查看器)工具。此应用只能连接到Android* 操作系统的开发人员版本中,所以在不用开发设备情况下,使用它的最简单的方法就是利用模拟器。通过命令行运行该工具:
hierarchyviewer
结论
希望我已为您的应用性能提升需要提供了一些新的工具与知识。除了使用这些工具来发现您在哪些方面可以获得增益外,很多性能改进可在代码级别实现。您可以在“Designing for Performance”(性能设计)一文中更多了解有关常见性能编码技术。