Android 性能优化 二 TraceView工具的使用

2023-11-03 08:08

本文主要是介绍Android 性能优化 二 TraceView工具的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、TraceView工具如何使用

TraceView有4种启动/关闭分析方式:

(1) 第一种使用方法演示

1、 选择跟踪范围

在想要根据的代码片段之间使用以下两句代码

[java]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. Debug.startMethodTracing("love_world_");  
  2. Debug.stopMethodTracing();  

例如,onCreate与onStart方法之间方法跟踪
[java]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. public class MainActivity extends Activity {  
  2.   
  3.     @Override  
  4.     protected void onCreate(Bundle savedInstanceState) {  
  5.         super.onCreate(savedInstanceState);  
  6.         setContentView(R.layout.activity_main);  
  7.           
  8.         Debug.startMethodTracing("Love_World_");  
  9.     }  
  10.   
  11.     @Override  
  12.     protected void onStart() {  
  13.         super.onStart();  
  14.           
  15.         Debug.stopMethodTracing();  
  16.     }  
  17.       
  18. }  




2、添加SD卡访问权限

[html]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>  
  2. <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>    


如果不添加,执行项目会出现以下异常
[java]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. java.lang.RuntimeException:Unable to open trace file '/mnt/sdcard/Love_World_.trace': Permission denied  

如果手机没有SD卡也会出现同样的问题

3、 导出traceview文件

1  首先执行项目,查看trace文件是否生成
进入shell模式

[sql]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. adb shell  

查看是否已经生成这个文件
[plain]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. ls sdcard/Love_World_.trace  

Ctrl + C 退出adb shell模式

2 导出trace文件
[plain]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. adb pull sdcard/Love_World_.trace  


4、 打开trace文件


打开trace文件需要Android提供的traceview.bat工具,工具所在目录:sdk\tools\traceview.bat, 有两种方式执行:
1) 在命令行中切换到此目录
2) 将此目录添加到系统环境变量中

[plain]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. //  cmd在calc.trace所在目录执行  
  2. traceview C:\Users\YourName\Desktop\Love_World_.trace  

其中“C:\Users\YourName\Desktop\” 表示trace所在你系统中的目录,此工具需要输入trace文件的绝对路径才行


在新版本的SDK 会有以下提示:

[java]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. The standalone version of traceview is deprecated.  
  2. Please use Android Device Monitor (tools/monitor) instead.  

所以建议使用tools/monitor 启动后跟Eclipse DDMS界面差不多,然后File -> Open File -> 选择trace文件

5、异常处理

1 异常处理
[plain]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. 'C:\Windows\system32\java.exe' 不是内部或外部命令,也不是可运行的程序  
  2. 或批处理文件。  
  3. SWT folder '' does not exist.  
  4. Please set ANDROID_SWT to point to the folder containing swt.jar for your platfo  
  5. rm.  

配置Java环境变量,把java bin 添加到系统环境变量PATH中



2 异常信息
[plain]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. The standalone version of traceview is deprecated.  
  2. Please use Android Device Monitor (tools/monitor) instead.  
  3. Failed to read the trace filejava.io.IOException: Key section does not have an *  
  4. end marker  
  5.         at com.android.traceview.DmTraceReader.parseKeys(DmTraceReader.java:420)  
  6.   
  7.   
  8.         at com.android.traceview.DmTraceReader.generateTrees(DmTraceReader.java:  
  9. 91)  
  10.         at com.android.traceview.DmTraceReader.<init>(DmTraceReader.java:87)  
  11.         at com.android.traceview.MainWindow.main(MainWindow.java:286)  

通常是trace文件有异常,再重新生成并导出试试

3. 没有SD卡会出现异常

[java]  view plain copy
print ? 在CODE上查看代码片 派生到我的代码片
  1. Unable to open trace file '/sdcard/Love_World_.trace': Permission denied  
  2.  Caused by: java.lang.RuntimeException: Unable to open trace file '/sdcard/Love_World_.trace': Permission denied  

生成的trace系统自动放在SDCARD上,没有sd卡所以会出现这种异常


(2)  第二种使用方法演示

Eclipse -> DDMS -> Start Method Profiling


二者的区别,第一种方式更精确到方法,不方便的地方是自己需要添加方法并且要导出文件,第二种方式的优缺点刚好相反。


(3) 任意时间点启动与关闭trace

启动:am profile <PROCESS> start <FILE>
关闭:am profile <PROCESS> stop


<PROCESS> 填写进程名,例如AndroidManifest.xml中声明的包名,通常都是主进程名


例如:  
adb shell am profile com.example start ./mnt/sdcard/test.trace


adb shell am profile com.example stop


(4)  启动指定Activity并进行trace

am start -n <Package Name>/<Package Name>.<Activity Name> --start-profiler <FILE>
例如:
adb shell am start -n com.example/com.example.MainActivity --start-profiler ./mnt/sdcard/test.trace


细节详见官方文档:

http://developer.Android.com/tools/help/shell.html


二、 TraceView工具面板介绍

有两方面用途: 

1  查看跟踪代码的执行时间,分析哪些是耗时操作  

2  可以用于跟踪方法的调用,尤其是Android Framework层的方法调用关系


获取方法的调用顺序

1. 在traceview中搜索响应的方法名不能使用大写字母

2. 搜索出的方法会自动展开,其中包含Parents 和 Children 两组信息

3. 点击Parents下的方法名,直接跳转到调用当前的方法处。Children相反




Traceview 面板分上下两部分
上面是时间轴面板 (Timeline Panel)
     左侧显示的是线程信息
     右侧黑色部分是显示执行时间段、白色是线程暂停时间段,
     右侧鼠标放在上面会出现时间线纵轴,在顶部会显示当前时间线所执行的具体函数信息
下面是分析面板(Profile Panel) -   每一列内容

Inclusive time  - 函数本身运行花费时间 + 函数调用其他函数时间

Exclusive time - 函数本身运行花费时间。

Calls + RecurCall/Total 调用 + 重复调用次数 / 函数总调用次数

Cpu Time/Call 总的Cpu时间与总的调用次数之比

1-1  Profile Panel各列作用说明

列名

描述

Name

该线程运行过程中所调用的函数名

Incl Cpu Time

某函数占用的CPU时间,包含内部调用其它函数的CPU时间

Excl Cpu Time

某函数占用的CPU时间,但不含内部调用其它函数所占用的CPU时间

Incl Real Time

某函数运行的真实时间(以毫秒为单位),内含调用其它函数所占用的真实时间

Excl Real Time

某函数运行的真实时间(以毫秒为单位),不含调用其它函数所占用的真实时间

Call+Recur Calls/Total

某函数被调用次数以及递归调用占总调用次数的百分比

Cpu Time/Call

某函数调用CPU时间与调用次数的比。相当于该函数平均执行时间

Real Time/Call

CPU Time/Call类似,只不过统计单位换成了真实时间




三、如何进行具体的分析

有两个问题需要解决:


1. 如何定位到所关心的地方? 

上面只是介绍了如何使用TraceView且有两种用法,但是有时使用第一种方式范围又不太精确,使用第二种添加代码的方式,可能有些地方又监听不到。这种情况可以尝试把开始或者结束放到延迟线程中,延迟一段时间在执行开始或者结束。


2. 如何查找出哪些地方比较耗时?

TraceView罗列出了是所有监听到的方法,当然也包括Android系统很多方法的耗时,如何在这么多方法里面查找到自己关心的? 可以通过TraceView 底部的find 来查找,通常Android app都是有包名的,可以先针对某些关心的列排序后,在通过包名进行一个个查找,这些就省去自己筛选出自己app 方法耗时排行的时间。


四、 相关资料:

Android系统性能调优工具介绍 (还有具体如何使用进行性能分析的例子,非常棒)
Profiling with Traceview and dmtracedump
Android 编程下的 TraceView 简介及其案例实战 (含例子)

念茜 : Android代码调试工具 traceview 和 dmtracedump的波折演绎 


原文地址: http://blog.csdn.net/love_world_/article/details/8223805



2014-07-07  更新第二种使用方式与参考资料
2014-07-10 更新一些细节与三、如何进行具体分析

这篇关于Android 性能优化 二 TraceView工具的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/336782

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没