IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> AS3,复习指南 -> 正文阅读

[移动开发]AS3,复习指南

根据Android系统,你在内存分析器的顶部看到的数字(如下图)基于你的应用所提交的所有私有内存页面。此计数不包括与系统或其他应用程序共享的页。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1t3P4Wy5-1630397795562)(https://user-gold-cdn.xitu.io/2017/12/16/1605fcb70499ec81?imageView2/0/w/1280/h/960/ignore-error/1)]

内存类别如下:

  • Java:从Java或Kotlin代码中分配的对象的内存
  • Native:从C或c++代码中分配的对象的内存,即使你没有在app中使用c++,你可能会看到一些本地内存,因为Android框架使用Native内存来处理各种任务,比如处理图像资产和其他图形——即使你写的代码是Java或Kotlin
  • Graphics:用于图形缓冲区队列的内存用于显示屏幕上的像素,包括GL表面、GL纹理等。(注意,这是与CPU共享的内存,而不是专用的GPU内存)
  • Stack:在你的应用程序中,Native和Java栈使用的内存。这通常与你的应用程序运行的线程数有关
  • Code:您的应用程序用于代码和资源的内存,如dex字节码,优化或编译的dex代码。所以库和字体
  • Other:应用程序使用的内存,系统不确定如何分类
  • Allocated:应用程序分配的Java/Kotlin对象的数量。这并不计算用C或c++分配的对象

注意:当前应用程序中,native内存统计值可能会偏大,因为分析工具的一部内存也被算进去了,多达10MB的内存被添加到~100k对象,在未来版本的工具中,这些数字将从您的数据中过滤出来。

2.3:查看内存分配情况

单击工具栏记录内存分配在内存分析器 我们想要查看某一时刻程序的内存分配情况也很简单,如下图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cGydHy9I-1630397795565)(https://user-gold-cdn.xitu.io/2017/12/18/160697c675cd8207?imageslim)]

最后的界面如下图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ni7OSP7d-1630397795566)(https://user-gold-cdn.xitu.io/2017/12/18/1606984ed4e7d90d?imageView2/0/w/1280/h/960/ignore-error/1)]

2.4 捕获heap dump

heap dump显示在你捕获heap dump时应用程序中的哪些对象正在使用内存,特别是在扩展的用户会话之后,heap dump可以通过显示仍在内存中的对象来帮助识别内存泄漏。一旦捕获heap dump,可以查看以下内容:

  • 应用分配了哪些类型的对象,以及每个对象的数量
  • 每个对象使用多少内存。
  • 每个对象的引用都被保存在你的代码中。
  • 调用堆栈分配对象的位置,(当您在录制分配时捕获heap dump 时,调用堆栈当前仅在Android 7.1中使用堆转储时才可用。

要捕获heap dump,在Memory Profiler工具栏中单击Dump Java heap按钮即可 在转储堆时,Java内存量可能会暂时增加,因为堆转储发生在和你的应用程序相同的进程,并需要一些内存来收集数据,heap dump出现在内存时间线下方,显示了堆中的所有类型,如图下图所示。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dwZnKXxK-1630397795567)(https://user-gold-cdn.xitu.io/2017/12/18/160699f9684dc3f8?imageView2/0/w/1280/h/960/ignore-error/1)]

在图中可以看到Class Name列表,,在列表中可以看到以下信息:

  • Alloc Count:堆中的分配数量。
  • Native Size:此对象类型使用的Native内存总量(以字节为单位),此列仅适用于Android 7.0及更高版本。 你会在这里看到一些在Java中分配的对象的内存,因为Android为一些框架类(比如Bitmap)使用本地内存。
  • Shallow Size:此对象类型使用的Java内存总量(以字节为单位)
  • Retained Size:由于此类的所有实例而保留的内存总大小(以字节为单位)在class 列表顶部,可以使用左侧的下拉列表在下列堆转储之间切换
  • Default heap:当系统没有指定堆时。
  • App heap:你的应用程序分配内存的主要堆。
  • Image heap:系统引导映像,包含在引导期间预加载的类,这里的分配保证不会移动或消失,
  • Zygote heap:Android系统中的应用程序进程分支的写入时复制堆。

2.5 将 heap dump 保存为 HPROF

如果你想保存 heap dump为日后查看,导出heap dump到一个HPROF文件的话,如需要点击 Export capture to file按钮,如下图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sqY3AgoR-1630397795568)(https://user-gold-cdn.xitu.io/2017/12/18/16069b437f9ba51c?imageView2/0/w/1280/h/960/ignore-error/1)]

如果你需要从Android HPROF文件格式转换为Java SE HPROF格式,可以使用hprof-conv工具进行转化,它的位置在 android_sdk/platform-tools/目录下,运行hprof-conv命令

hprof-conv heap-original.hprof heap-converted.hprof 

3:CPU分析工具(CPU Profiler)

当你打开CPU分析器,它会立即开始显示应用程序的CPU使用率和线程的活动,如下图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZaD33OvO-1630397795569)(https://user-gold-cdn.xitu.io/2017/12/19/1606d739419c07dc?imageView2/0/w/1280/h/960/ignore-error/1)]

CPU Profiler的默认视图包含以下内容:

1

:Event timeline:显示应用在他们的生命周期中不同状态间转换时的活动,并指示用户与设备的交互,包括屏幕旋转事件

2

:CPU timeline:显示应用程序的实时CPU使用情况(占可用CPU总时间的百分比)以及应用程序正在使用的线程总数。时间表还显示了其他进程(如系统进程或其他应用程序)的CPU使用情况,因此您可以将其与应用程序的使用情况进行比较。可以通过沿着时间轴的横轴移动鼠标来检查历史CPU使用率数据。

3

:Thread activity timeline:列出属于你的应用程序进程的每个线程,并使用下面列出的颜色在时间线上指示其活动。记录方法跟踪之后,可以从此时间线中选择一个线程,以在跟踪窗格中检查其数据。

  • 绿色:线程处于活动状态或准备好使用CPU。也就是说,它处于“运行”或“可运行”状态。
  • 黄色:线程处于活动状态,但它正在等待I / O操作(例如磁盘或网络I / O),然后才能完成工作。
  • 灰色:线程正在休眠,不占用任何CPU时间。当线程需要访问尚不可用的资源时,有时会发生这种情况。线程进入自愿睡眠,或者内核使线程进入休眠状态,直到需要的资源变为可用。

4

:Recording configurations:允许您选择以下选项之一来确定探查器如何记录方法跟踪。

  • Sampled(采样):一个默认配置,可以在应用程序执行期间频繁地捕获应用程序的调用堆栈。分析器比较捕获的数据集合以获取关于应用代码执行的时间和资源使用信息。基于抽样的跟踪的一个固有问题是,如果您的应用程序在捕获调用堆栈之后输入方法,并在下次捕获之前退出该方法,则该方法调用不会被分析器记录。如果您对如此短的生命周期跟踪方法感兴趣,则应使用检测跟踪。

  • Instrumented:默认配置,在运行时测试您的应用程序,以在每个方法调用的开始和结束时记录一个时间戳。收集时间戳并进行比较,以生成方法跟踪数据,包括定时信息和CPU使用情况。请注意,与每种方法相关的开销都会影响运行时性能,并可能影响分析数据 - 对于生命周期相对较短的方法来说,这一点更为明显。此外,如果您的应用程序在很短的时间内执行大量方法,分析器可能会快速超出其文件大小限制,并且无法记录任何进一步的跟踪数据。

  • Edit configurations:允许您更改上述采样和检测记录配置的某些默认设置,并将其保存为自定义配置。

5

:Record button:开始和停止录制方法跟踪按钮

4:网络分析工具(Network Profiler)

网络分析工具比较简单,界面如下图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-U48e775S-1630397795570)(https://user-gold-cdn.xitu.io/2017/12/19/1606e91a1edee4ce?imageView2/0/w/1280/h/960/ignore-error/1)]

窗口的顶部的

1

处,可以看见wifi无线信号的强弱,在时间线上可以在

2

处点击和拖动一部分的时间线来检测流量,然后在窗口

3

中会显示所选时间段内收发的文件,包括文件名,大小,类型,状态和花费时间,你可以对窗口

3

的列表根据列来进行排序。还可以查看所选时间段的详细拆分,拆分的timeline可以显示文件是什么时候收发的,点击窗口3的其中一个文件,可以在窗口

4

中查看文件的详细信息。通过切换窗口

4

类型,状态和花费时间,你可以对窗口

3

的列表根据列来进行排序。还可以查看所选时间段的详细拆分,拆分的timeline可以显示文件是什么时候收发的,点击窗口3的其中一个文件,可以在窗口

4

中查看文件的详细信息。通过切换窗口

4

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-09-01 12:02:26  更:2021-09-01 12:04:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年10日历 -2024/10/24 4:29:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码