1、时间测量

System.currentTimeMillis     精读和准确度可能不够;更改系统时间会影响结果;UTC时间1970/1/1 00:00:00到现在的毫秒数

System.nanoTime        没有定义参考时间,只能用来测量时件间隔;别的线程会导致测量时间不正确

Debug.threadCpuTimeNanos   只测量当前线程中所花费的时间,所以它的结果更准确;如果遥测梁的部分运行在多个线程上,要测量每个线程,并相加

System.currentThreadTimeMillis  

System.elapsedRealtime

System.uptimeMillis

需调用两次,求差值

2、方法调用跟踪

(1)Debug.startMethodTracing()  由Android提供,创建跟踪文件。用Traceview工具调试和分析应用。有四个变种:

startMethodTracing()

startMethodTracing(String traceName)

startMethodTracing(String traceName, int bufferSize)

startMethodTracing(String traceName, int bufferSize, int flags)

traceName  记录保存的文件名,就跟log.txt一样。如果已经存在会被截断。保证有权限和路径

bufferSize   文件大小(默认8MB)

flags       只有一个,Debug.TRACE_COUNT_ALLOCS。可以是0 或者 Debug.TRACE_COUNT_ALLOCS

对应的有  stopMethodTracing

实例代码

Debug.startMethodTracing("/sdcard/awesometrace.trace") ;

//需要跟踪的操作

BigInteger fN = Fibonacci.computeRecursivelyWithCache();

Debug.stopMethodTracing();

// 现在在/mnt/sdcard 目录下会有awesometrace.trace文件。 在DDMS中pull出  或者adb pull

(2)tools下有TraceView工具。命令行:traceview awesometrace.trace 启动

Name 方法名

Incl % 此方法中占的时间百分比(包含子方法)

Inclusive 此方法中所花的毫秒数(包含子方法)

Excl % 此方法中占的时间百分比(不包含子方法)

Exclusive 此方法中所花的毫秒数(不包含子方法)

Calls+RecurCalls/Total 调用和递归调用次数

Time/Call 平均每次调用时间

Parents 此方法的调用者

Children 此方法调用的方法

Parents while recursive递归时此方法的调用者

Children while recursive递归时此方法调用的方法

时间轴可以拖拽 方法和缩小

注:正常情况,方法可以被Dalvik的JIT编译器编译为机器码。

但是模拟跟踪时JIT编译器是禁用的。所以实际中,真实场景中花费的时间应该比显示出来的更少一些。

(3)在DDMS中启动TraceView。需要点击开始跟踪,再次点击之后停止。

3、Log

verbose(log.v)

debug(log.d)

info(log.i)

warning(log.w)

error(log.e)

assert(log.wtf)

Log.println(Log.DEBUG, TAG, "message") 相当于Log.d(...)

注:Log.wtf()方法在API8引入。但是Log.ASSERT在API 1就有了

因此要兼容 要使用Log.println(Log.VERBOSE, TAG, "message")而不是Log.wtf(...)

《Android应用性能优化》 第6章 性能评测和剖析的更多相关文章

  1. Linux性能优化 第五章 性能工具:特定进程内存

    5.1 Linux内存子系统 在诊断内存性能问题的时候,也许有必要观察应用程序在内存子系统的不同层次上是怎样执行的.在顶层,操作系统决定如何利用交换内存和物理内存.它决定应用程序的哪一块地址空间将被放 ...

  2. Linux性能优化 第七章 性能工具:网络

    7.1 网络I/O介绍 Linux和其他主流操作系统中的网络流量被抽象为一系列的硬件和软件层次. 链路层,也就是最低的一层,包含网络硬件,如以太网设备.在传送网络流量时,这一层并不区分流量类型,而仅仅 ...

  3. Linux性能优化 第六章 性能工具:磁盘I/O

    6.1 磁盘I/O介绍 一般来说,Linux磁盘的每个分区要么包含一个文件系统,要么包含一个交换分区.这些分区被挂载到Linux根文件系统,该系统由/etc/fstab指定.这些被挂载的文件系统包含了 ...

  4. Linux性能优化 第三章 性能工具:系统内存

    3.1内存性能统计信息 3.1.1 内存子系统和性能 和CPU相比,内存的读写速度都大大落后于CPU.为了弥补这个差距,通常CPU会采用高速缓存的机制(高cache). 3.1.2 内存子系统(虚拟存 ...

  5. Linux性能优化 第四章 性能工具:特定进程CPU

    4.1进程性能统计信息 4.1.1. 内核时间VS用户时间 一个应用程序所耗时间最基本的划分是内核时间与用户时间.内核时间是消耗在Linux内核上的时间,而用户时间则是消耗在应用程序或库代码上的时间. ...

  6. Android性能优化之UI渲染性能优化

    版权声明:本文出自汪磊的博客,未经作者允许禁止转载. 本篇博客主要记录一些工作中常用的UI渲染性能优化及调试方法,理解这些方法对于我们编写高质量代码也是有一些帮助的,主要内容包括介绍CPU,GPU的职 ...

  7. Android性能优化之提高ListView性能的技巧

    ListView优化一直是一个老生常谈的问题.无论是面试还是寻常的开发中,ListView永远不会被忽略掉,那么这篇文章我们来看看怎样最大化的优化ListView的性能. 1.在adapter中的ge ...

  8. EF性能优化-有人说EF性能低,我想说:EF确实不如ADO.NET

    十年河东,十年河西,莫欺少年穷. EF就如同那个少年,ADO.NET则是一位壮年.毕竟ADO.NET出生在EF之前,而EF所走的路属于应用ADO.NET. 也就是说:你所写的LINQ查询,最后还是要转 ...

  9. 经典的性能优化最佳实践 web性能权威指南 读书笔记

    web性能权威指南 page 203 经典的性能优化最佳实践 无论什么网络,也不管所用网络协议是什么版本,所有应用都应该致力于消除或减 少不必要的网络延迟,将需要传输的数据压缩至最少.这两条标准是经典 ...

  10. Java性能优化,操作系统内核性能调优,JYM优化,Tomcat调优

    文章目录 Java性能优化 尽量在合适的场合使用单例 尽量避免随意使用静态变量 尽量避免过多过常地创建Java对象 尽量使用final修饰符 尽量使用局部变量 尽量处理好包装类型和基本类型两者的使用场 ...

随机推荐

  1. review07

    java类可以有两种重要的成员:成员变量和方法,实际上java还允许有一种成员:内部类.内部类是在一个类中定义另一个类.内部类和外嵌类的关系如下: (1)内部类的外嵌类的成员变量在内部类中仍然有效,内 ...

  2. SQL SERVER 集合

    死锁和堵塞一直是性能测试执行中关注的重点. 下面是我整理的监控sql server数据库,在性能测试过程中是否出现死锁.堵塞的SQL语句,还算比较准备,留下来备用. --每秒死锁数量 SELECT * ...

  3. python递归中的return"陷阱"

    在做一道练习题(参照下篇博文<在当前目录下递归的查找包含指定字符串的文件>)的时候,发现函数中的return的值竟然是None,百思不得其解,尝试化繁为简,用以下的简单的代码验证了一下 问 ...

  4. 卸载全部appx应用(包括应用商店)

    在PowerShell中粘贴: Get-AppXPackage | Remove-AppxPackage

  5. Django 基础 模板系统

    Django模板系统 官方文档 常用语法 只需要记两种特殊符号: {% %} 'b', 'c', 'd']的话,就显示4. filesizeformat 将值格式化为一个 “人类可读的” 文件尺寸 ( ...

  6. set/multiset和map/multimap用法小结

    二叉搜索树是ACM中经常需要用到的数据结构,熟练掌握map和set的用法很关键,现对其做一个简单的总结. 主要的功能有:插入元素,查找元素,删除,遍历/反向遍历. 插入,删除和查找操作的时间都和树的高 ...

  7. SQL Server数据文件迁移

    需求:源SQL Server安装目录及数据目录 与 目标SQL Server安装目录及数据目录 完全不同. 步骤: 1.拷贝源数据目录下需要移植的库文件(rpBrInfo_TA.mdf.rpBrInf ...

  8. Django 登录页面重定向

    转自:http://blog.chedushi.com/archives/3484 登陆和注销操作在网页编程上很常见,这两个操作经常需要在操作成功以后转入发出请求的页面. 比如用户正在浏览一篇文章,发 ...

  9. mongodb所在目录空间不足解决方法

    1.原理是将目录/home/aa软连接到/usr/lib/下,以后从/usr/lib下读取的内容其实都是放在/home/aa下. 建议不要大范围动/usr下的内容,咋着也是属于系统目录,可能会对已装软 ...

  10. 关于讯飞语音SDK开发学习

    前奏,浑浑噩噩已经工作一年多,这一年多收获还是挺多的.逛园子应该有两年多了,工作后基本上是天天都会来园子逛逛,园子 里还是有很多牛人写了一些不错的博客,帮我解决很多问题.但是一直没写过博客,归根到底一 ...