一、TraceView工具如何使用

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

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

1、 选择跟踪范围

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

Debug.startMethodTracing("love_world_");  
Debug.stopMethodTracing(); 

例如,onCreate与onStart方法之间方法跟踪

public class MainActivity extends Activity {  
  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_main);  
          
        Debug.startMethodTracing("Love_World_");  
    }  
  
    @Override  
    protected void onStart() {  
        super.onStart();  
          
        Debug.stopMethodTracing();  
    }  
      
}  

2、添加SD卡访问权限

uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>  
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>

如果不添加,执行项目会出现以下异常

java.lang.RuntimeException:Unable to open trace file '/mnt/sdcard/Love_World_.trace': Permission denied  

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

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

adb shell 

2 导出trace文件

adb pull sdcard/Love_World_.trace  

4、 打开trace文件

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

//  cmd在calc.trace所在目录执行  
traceview C:\Users\YourName\Desktop\Love_World_.trace  

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

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

The standalone version of traceview is deprecated.  
Please use Android Device Monitor (tools/monitor) instead.

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

5、异常处理
1 异常处理

'C:\Windows\system32\java.exe' 不是内部或外部命令,也不是可运行的程序  
或批处理文件。  
SWT folder '' does not exist.  
Please set ANDROID_SWT to point to the folder containing swt.jar for your platfo  
rm.  

  配置Java环境变量,把java bin 添加到系统环境变量PATH中
2 异常信息

The standalone version of traceview is deprecated.  
Please use Android Device Monitor (tools/monitor) instead.  
Failed to read the trace filejava.io.IOException: Key section does not have an *  
end marker  
        at com.android.traceview.DmTraceReader.parseKeys(DmTraceReader.java:420)  
  
  
        at com.android.traceview.DmTraceReader.generateTrees(DmTraceReader.java:  
91)  
        at com.android.traceview.DmTraceReader.<init>(DmTraceReader.java:87)  
        at com.android.traceview.MainWindow.main(MainWindow.java:286) 

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

3. 没有SD卡会出现异常

Unable to open trace file '/sdcard/Love_World_.trace': Permission denied  
 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  可以用于跟踪方法的调用,尤其是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系统性能调优工具介绍 (还有具体如何使用进行性能分析的例子,非常棒)

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

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

  

  

  

  

  

  

  

  

  

Android 手机卫士13--进程设置的更多相关文章

  1. Android 手机卫士--设置界面&功能列表界面跳转逻辑处理

    在<Android 手机卫士--md5加密过程>中已经实现了加密类,这里接着实现手机防盗功能 本文地址:http://www.cnblogs.com/wuyudong/p/5941959. ...

  2. Android 手机卫士--确认密码对话框编写

    本文接着实现“确认密码”功能,也即是用户以前设置过密码,现在只需要输入确认密码 本文地址:http://www.cnblogs.com/wuyudong/p/5940718.html,转载请注明出处. ...

  3. Android 手机卫士--弹出对话框

    在<Android 手机卫士--解析json与消息机制发送不同类型消息>一文中,消息机制发送不同类型的信息还没有完全实现,在出现异常的时候,应该弹出吐司提示异常,代码如下: private ...

  4. android手机卫士、3D指南针、动画精选、仿bilibli客户端、身份证银行卡识别等源码

    Android精选源码 android身份证.银行卡号扫描源码 android仿bilibili客户端 android一款3D 指南针 源码 android手机卫士app源码 android提醒应用, ...

  5. Android 手机卫士--参照文档编写选择器

    本文来实现<Android 手机卫士--导航界面1的布局编写>中的图片选择器部分的代码. 本文地址:http://www.cnblogs.com/wuyudong/p/5944356.ht ...

  6. Android 手机卫士--签名文件说明&包名说明

    在<Android 手机卫士--打包生成apk维护到服务器>一文中,实现了新版本的apk到服务器,当打开客户端apk的时候,发现有新版本,提示更新.还实现了利用xutils工具实现了从服务 ...

  7. Android 手机卫士--阶段小结1

    本文地址:http://www.cnblogs.com/wuyudong/p/5904528.html,转载请注明源地址. 本文对之前手机卫士开发进行一个小结. 1.SplashActivity 版本 ...

  8. Android 手机卫士--xutils说明与下载方法使用

    xUtils简介 xUtils 包含了很多实用的android工具. xUtils 最初源于Afinal框架,进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持(10种谓词) ...

  9. [android] 手机卫士自定义滚动控件

    TextView控件设置单行显示 android:singleLine=”true” 设置TextView开始的位置显示省略号,android:ellipsize=”start” 设置滚动属性,and ...

随机推荐

  1. [原创]Android Studio的Instant Run(即时安装)原理分析和源码浅析

    Android Studio升级到2.0之后,新增了Instant Run功能,该功能可以热替换apk中的部分代码,大幅提高测试安装的效率. 但是,由于我的项目中自定义了一些ClassLoader,当 ...

  2. [LeetCode] Sparse Matrix Multiplication

    Problem Description: Given two sparse matrices A and B, return the result of AB. You may assume that ...

  3. centos6.5+jexus5.6.3+mono 3.10实践,让asp.net在linux上飞一会儿

    备忘,这是给自己看的,用ubuntu server装mono 3.10老是卡在了编译libgdiplus上面,从来就没成功过,郁闷啊,零零散散搞了好几天,作罢.后来试了OpenSUSE 11很容易搞好 ...

  4. 转载 jquery $(document).ready() 与window.onload的区别

    Jquery中$(document).ready()的作用类似于传统JavaScript中的window.onload方法,不过与window.onload方法还是有区别的. 1.执行时间 windo ...

  5. TWaver家族新成员 — Legolas工业自动化设计平台

    对于TWaver可视化家族的成员,大家比较熟悉的是我们的网络拓扑图组件和MONO Design三维建模工具.作为开发工具,这两款产品面向广大的程序猿同志,在界面可视化上为大家省时省力.但是,当项目交付 ...

  6. android手势创建及识别

    使用一些浏览器或者输入法应用时会有一些手势操作,还可以自定义手势.这些神奇的操作是怎么做的呢?这一篇重点记录手势的识别和创建.这篇的内容使用到的是android.gesture包,具体的例子参考的是S ...

  7. C#中,接口不能被实例化,但存在特例

    看一个例子: interface IFoo { string Message { get; } } 则, IFoo obj = new IFoo("abd"); 将会报错:接口不能 ...

  8. Web程序员开发App系列 - 调试Android和IOS手机代码(补图)

    Web程序员开发App系列 Web程序员开发App系列 - 认识HBuilder Web程序员开发App系列 - 申请苹果开发者账号 Web程序员开发App系列 - 调试Android和iOS手机代码 ...

  9. .Net魔法堂:史上最全的ActiveX开发教程——开发篇

    一.前言 在设计某移动内部自动化运维平台时,经综合考虑终端机性能和功能需求等因素后,决定采用B/S模式,并且浏览器通过ActiveX组件实现与服务器Agent作P2P的通讯.好处,整个平台以网页形式存 ...

  10. [SQL] SQL SERVER基础语法

    Struct Query Language 1.3NF a.原子性 b.不能数据冗余 c.引用其他表的主键 2.约束 a.非空约束 b.主键约束 c.唯一约束 d.默认约束 e.检查约束 f.外键约束 ...