Android studio 性能调试

打印 上一主题 下一主题

主题 845|帖子 845|积分 2535

一、概述

        Android studio 的Profiler可用来分析cpu和memory问题,下来进行说明介绍
二、Android studio CPU调试

从开发模拟器或设备中启动应用程序;
在 Android Studio 中,通过选择View > Tool Windows > Profiler启动分析器。
应用程序启动后,单击 + 分析器中的按钮以查看下拉菜单。选择设备,然后在其他可分析历程下选择应用程序的条目。
选择监测CPU,可以看到线程和CPU占用信息


   官网解释:
  

  • 变乱时间线:表现应用程序中在生命周期中不同状态之间转换的活动,并指示用户与设备的交互,包括屏幕旋转变乱。有关在运行 Android 7.1(API 级别 25)及更低版本的设备上启用变乱时间线的信息,请参阅 启用高级分析。
  • CPU 时间线:表现应用程序的及时 CPU 使用情况(占总可用 CPU 时间的百分比)以及应用程序正在使用的线程总数。时间线还表现其他历程(例如体系历程或其他应用程序)的 CPU 使用情况,因此您可以将其与应用程序的使用情况进行比较。您可以通过沿着时间线的程度轴移动鼠标来查抄汗青 CPU 使用率数据。
  • 线程活动时间线:列出属于您的应用程序历程的每个线程,并使用下面列出的颜色沿着时间线指示其活动。记载跟踪后,您可以从此时间线中选择一个线程,以在跟踪窗格中查抄其数据。

    • 绿色:线程处于活动状态或准备好使用 CPU。也就是说,它处于正在运行或可运行状态。
    • 黄色:线程处于活动状态,但正在等候 I/O 操作(例如磁盘或网络 I/O),然后才能完成其工作。
    • 灰色:线程正在休眠,不消耗任何 CPU 时间。当线程须要访问尚不可用的资源时,有时会发生这种情况。线程要么进入自愿睡眠状态,要么内核将线程置于睡眠状态,直到所需的资源可用。
    CPU Profiler 还报告 Android Studio 和 Android 平台添加到应用程序历程中的线程的 CPU 使用情况,例如JDWP、 Profile Saver、Studio:VMStats、 Studioerfa和Studio:Heartbeat(只管线程活动时间线中表现的确切名称大概有所不同)。Android Studio 会报告此数据,以便您可以确定线程活动和 CPU 使用率实际上是由应用代码引起的。

  三、Android studio Memory调试

选择监测memory:

   官网说明:
  

  • Java: Memory from objects allocated from Java or Kotlin code.
  • Native: Memory from objects allocated from C or C++ code.
    Even if you're not using C++ in your app, you might see some native memory used here because the Android framework uses native memory to handle various tasks on your behalf, such as when handling image assets and other graphics—even though the code you've written is in Java or Kotlin.
  • Graphics: Memory used for graphics buffer queues to display pixels to the screen, including GL surfaces, GL textures, and so on. (Note that this is memory shared with the CPU, not dedicated GPU memory.)
  • Stack: Memory used by both native and Java stacks in your app. This usually relates to how many threads your app is running.
  • Code: Memory that your app uses for code and resources, such as dex bytecode, optimized or compiled dex code, .so libraries, and fonts.
  • Others: Memory used by your app that the system isn't sure how to categorize.
  • Allocated: The number of Java/Kotlin objects allocated by your app. This does not count objects allocated in C or C++.
    When connected to a device running Android 7.1 and lower, this allocation count starts only at the time the Memory Profiler connected to your running app. So any objects allocated before you start profiling are not accounted for. However, Android 8.0 and higher includes an on-device profiling tool that keeps track of all allocations, so this number always represents the total number of Java objects outstanding in your app on
  四、Android studio logcat调试

点击如下红框进行logcat调试:
过滤条件:
//输入package:(输入一个p就会有提示的) ,+ 你的包名 package:com.test.test
// 输入level: ,后面加上等级,如info,debug,warning等 // 当等级为Info时,过滤Info及以上的日记 level:debug
// 输入tag: ,后面跟上你要过滤的TAG,此功能同老版本的AS tag:TAG
// 输入message: +过滤的关键字 message:KW


 具体可 参考官网:
Profile your app performance  |  Android Studio  |  Android Developers

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

卖不甜枣

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表