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

  次阅读 作者:智能小宝 来源:互联网 2016-01-14 13:03 我要评论(0)

Android 程序调试工具

Google为我们提供的代码调试工具的亮点:traceview 和 dmtracedump 。有了这两个工具,我们调试程序分析bug就非常得心应手了。traceview帮助我们分析程序性能,dmtracedump生成函数调用图。遗憾的是,google提供的dmtracedump是个失败的工具,并不能绘图,本文会详细介绍解决方案,实现绘图。

生成.trace文件

android.os.Debug类,其中重要的两个方法Debug.startMethodTracing()和 Debug.stopMethodTracing()。这两个方法用来创建.trace文件,将从Debug.startMethodTracing() 开始,到Debug.stopMethodTracing()结束,期间所有的调用过程保存在.trace文件中,包括调用的函数名称和执行的时间等信 息。

把下面代码分别在加在调试起始代码的位置,和终止位置。

Debug.startMethodTracing( test );

Debug.stopMethodTracing();

其中参数test是要创建的trace文件的名称,test.trace。默认路径是/sdcard/test.trace,也可以自己制定/data/log/test,表示文件在/data/log/test.trace。

琧爀愀挀攀瘀椀攀眀

在SDK中执行:

./traceview test.trace

我们可以得到

1.程序中每个线程调用方法的启动和停止时间

2.函数执行的信息和效率分析

搧洀琀爀愀挀攀搀甀洀瀀

dmtracedump原本的用意是将整个调用过程和时间分析结合,以函数调用图的形式表现出来。可是google这个项目一直处于broken状态, 迟迟不能得到完善。现在的dmtracdump只有-o选项可以使用,在终端上列出函数调用信息,和traceview功能相似,如果执 行./dmtracedumpg test.png test.trace就会卡住不动。

起初我以为是test.trace文件的问题,对文件的结束符稍作修改,画出了一副雷人的图片:

后来,搜到了网络上有牛人提供了 dmtracedump的替代(这是原文链接),是一个python脚本,借助dot来绘制矢量图。python脚本一定要注意对齐格式,对齐缩进就是他的逻辑结构。

#!/usr/bin/env python

"""

turn the traceview data into a jpg pic, showing methods call relationship

"""

import sys

import os

import struct

import re

################################################################################

########################Global Variable#####################################

################################################################################

target_thread=1 #the thread that we want to track, filt out other threads

#all_actions = ["enter","exit","exception","reserved"]

all_threads = {}

all_methods = {}

all_records = []

parent_methods = {}

child_methods = {}

method_calls = {}

################################################################################

##############################Methods#####################################

################################################################################

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...