热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

eclipse使用教程_在Eclipse中使用AndroidTraceview

eclipse使用教程解决Android应用程序性能问题的最佳方法是通过跟踪执行来分析应用程序。这样,您可以根据实际数据来决定要改进的内容,并检测应用程
eclipse使用教程

eclipse使用教程

解决Android应用程序性能问题的最佳方法是通过跟踪执行来分析应用程序。 这样,您可以根据实际数据来决定要改进的内容,并检测应用程序中的瓶颈。 在Android SDK中,Debug对象处理配置文件,TraceView实用程序用于查看生成的跟踪文件。 我将描述如何使用Eclipse Android SDK插件中包含的工具进行概要分析,但是您也可以使用traceview命令。

请记住,.trace文件可能会变得很大,因此请注意仅跟踪应用程序中有问题的部分。 如果您不知道要概要分析的内容,则可以在第一时间进行大量跟踪,然后再深入到特定部分。 另外,在跟踪方法时执行速度会变慢,因此您只应将跟踪的执行时间与另一个跟踪的时间进行比较。

从代码分析

通过对代码进行性能分析,您可以分析已经怀疑有问题的部分。 要从代码进行剖析:

  1. 将调用添加到要在其中启动和停止分析的Debug类方法。 要开始使用任何方法进行性能分析,请添加以下方法调用:

    Debug.startMethodTracing("logname");

    要停止分析,请添加以下调用:

    Debug.stopMethodTracing();

    这些调用不必使用相同的方法,但是请确保将达到stopMethodTracing 。 另外,您的应用程序必须具有写入SD卡的权限,否则您将获得异常无法打开跟踪文件“ /sdcard/logcat.trace”:权限被拒绝

  2. 启动应用程序并执行有问题的操作以对其进行跟踪。 分析开始和停止时,Logcat输出中会显示一条消息,并且将在设备文件系统的根目录中创建一个logname.trace文件。
  3. 导航到设备SD卡的根目录,然后将.trace文件复制到桌面。 使用eclipse打开.trace文件,它将显示在跟踪工具中。 请参阅下面的分析.trace文件部分以检查结果。

从Eclipse剖析

在调试过程中进行性能分析可以使您查明在执行过程中随机出现的问题,或者不确定导致问题的代码行。

    1. 在DDMS透视图中,单击“启动方法分析”按钮。

SNAGHTML69d982c_thumb

  • 再按一次相同的按钮( Stop Method Profiling )停止分析。 结果将立即显示在Eclipse中。

分析.trace文件

打开.trace文件时,显示以下窗口:

图片

在顶部,每个线程都有自己的时间轴。 在此应用程序中,只有一个主线程,其他线程是系统线程。 我认为,最有趣的列是:

  • Incl CPU%:此方法使用的总CPU时间的百分比,包括所有子方法的执行时间。
  • 包括CPU时间:此方法使用的CPU时间(以毫秒为单位),包括所有子方法的执行时间。
  • 调用+ RecurCall /总计:父方法对子方法的调用次数(以及递归调用)/整个.trace文件对方法的总调用次数。

您可以展开任何方法以查看子方法并进行分析。 在这种情况下,对generateRandomNumber方法进行细化显示,子方法saveRandomNumber占据了大部分执行时间。 实际上,如果您查看“呼叫”列,则可以看到它被调用了1000000次。 该方法在测试中被多次调用,但是对于真实的分析案例,这是您要注意的地方:可以减少调用次数,或者可以优化方法的执行。

翻译自: https://www.javacodegeeks.com/2014/06/using-android-traceview-in-eclipse.html

eclipse使用教程



推荐阅读
  • 本文针对初学者在创建Android项目时遇到的R.java文件错误提供了解决方案,通过实际案例和详细的日志分析,帮助读者快速定位并解决问题。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 深入理解Java中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 作为一名新手,您可能会在初次尝试使用Eclipse进行Struts开发时遇到一些挑战。本文将为您提供详细的指导和解决方案,帮助您克服常见的配置和操作难题。 ... [详细]
  • ASP.NET MVC中Area机制的实现与优化
    本文探讨了在ASP.NET MVC框架中,如何通过Area机制有效地组织和管理大规模应用程序的不同功能模块。通过合理的文件夹结构和命名规则,开发人员可以更高效地管理和扩展项目。 ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 深入理解ExtJS:从入门到精通
    本文详细介绍了ExtJS的功能及其在大型企业前端开发中的应用。通过实例和详细的文件结构解析,帮助初学者快速掌握ExtJS的核心概念,并提供实用技巧和最佳实践。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
author-avatar
夡敧
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有