聊城宏远网站建设优化网站建设中 单页
web/
2025/10/1 13:41:53/
文章来源:
聊城宏远网站建设优化,网站建设中 单页,免费源码分享网站,大学生活网站设计目录 Android Studio中内存分析工具Memory profiler的使用1. 打开Memory Profiler2. 工具使用3. 内存选项说明4. 内存性能分析器概览5. 内存计算方式6. 查看内存分配7. 捕获java/kotlin方式查看内存分配8. 堆转储文件导入和导出 内存性能分析器中的泄漏检测 Android Studio中内… 目录 Android Studio中内存分析工具Memory profiler的使用1. 打开Memory Profiler2. 工具使用3. 内存选项说明4. 内存性能分析器概览5. 内存计算方式6. 查看内存分配7. 捕获java/kotlin方式查看内存分配8. 堆转储文件导入和导出 内存性能分析器中的泄漏检测 Android Studio中内存分析工具Memory profiler的使用
参考文章
1. 打开Memory Profiler
有两种方式打开第一种通过标题栏打开 第二种通过下方菜单栏打开
2. 工具使用
打开后是这样的 打开后点击 号选择自己包名 选择完成后就会创建你项目的SESSIONS界面 如果想删除这个SESSIONS右键删除 点击memory这一列 点击后到内存捕获类型页面
3. 内存选项说明
捕获堆转储(Capture heap dump)查看应用程序中在特定时间点使用内存的对象记录Native分配(Record native allocations)查看每个C/C对象在一段时间内是如何分配的记录java/kotlin分配(Record java/kotlin allocations)查看在一段时间内如何分配每个java/kotlin对象 然后是这个页面 然后看到这个页面
4. 内存性能分析器概览
原文链接 内存性能分析图 当您首次打开内存性能分析器时您将看到一条表示应用内存使用量的详细时间轴并可使用各种工具强制执行垃圾回收、捕获堆转储以及记录内存分配
用于强制执行垃圾回收事件的按钮用于捕获堆转储的按钮用于指定性能分析器多久捕获一次内存分配的下拉菜单用于缩放时间轴的按钮用于跳转到实时内存数据的按钮事件时间轴显示活动状态、用户输入事件和屏幕旋转事件内存使用量时间轴它会显示以下内容
一个堆叠图表显示每个内存类别当前使用多少内存如左侧的 y 轴以及顶部的彩色键所示一条虚线表示分配的对象数如右侧的 y 轴所示每个垃圾回收事件的图标
5. 内存计算方式
内存性能分析器顶部看到的数字 内存计数中的类别如下
Java从 Java 或 Kotlin 代码分配的对象的内存Native从 C 或 C 代码分配的对象的内存Graphics图形缓冲区队列为向屏幕显示像素包括 GL 表面、GL 纹理等等所使用的内存Stack您的应用中的原生堆栈和 Java 堆栈使用的内存。这通常与您的应用运行多少线程有关Code您的应用用于处理代码和资源如 dex 字节码、经过优化或编译的 dex 代码、.so 库和字体的内存Others您的应用使用的系统不确定如何分类的内存Allocated您的应用分配的 Java/Kotlin 对象数。此数字没有计入 C 或 C 中分配的对象
6. 查看内存分配
选择Capture heap dump并点击Record按钮开始捕获捕获完成后点击Stop进行分析 查看捕获结果 检查分配记录步骤
点击 Class Name 列标题以按字母顺序排序。然后点击一个类名称。此时下侧将出现Instance View 窗格显示该类的每个实例在 Instance View 窗格中点击一个实例。此时下方将出现 References 标签页显示该实例被4. 分配到何处以及在哪个线程中。在 References 标签页中右键点击任意行并选择 Jump to Source以在编辑器中打开该代码
菜单查看说明 菜单-检查的堆
default heap当系统未指定堆时image heap系统启动映像包含启动期间预加载的类。此处的分配确保绝不会移动或消失zygote heap写时复制堆其中的应用进程是从 Android 系统中派生的app heap您的应用在其中分配内存的主堆JNI heap显示 Java 原生接口 (JNI) 引用被分配和释放到什么位置的堆
菜单-分配 Arrange by class根据类名称对所有分配进行分组。这是默认值 Arrange by package根据软件包名称对所有分配进行分组 Arrange by callstack将所有分配分组到其对应的调用堆栈 捕获Native方式查看内存分配 捕获Native native结果数据 结果信息说明 Allocations在选定时间段内通过 malloc() 或 new 运算符分配的对象数 Deallocations在选定时间段内通过 free() 或 delete 运算符解除分配的对象数 Allocations Size在选定时间段内所有分配的总大小以字节为单位 Deallocations Size在选定时间段内所有已释放内存的总大小以字节为单位 Total CountAllocations 列中的值减去 Deallocations 列中的值所得的结果 Remaining SizeAllocations Size 列中的值减去 Deallocations Size 列中的值所得的结果
7. 捕获java/kotlin方式查看内存分配 Allocation Tracking下拉菜单说明
Full捕获内存中的所有对象分配。这是 Android Studio 3.2 及更低版本中的默认行为Sampled定期对内存中的对象分配情况进行采样。Off停止跟踪应用的内存分配
8. 堆转储文件导入和导出
堆转储文件导出 在Sessions列表中点击会话条目右侧的 Export method trace 或 Export system trace 按钮 堆转储文件导入 Sessions 窗格中点击 Start new profiler session 图标然后选择 Load from file
内存性能分析器中的泄漏检测 检查内存泄漏 捕获堆转储(Capture heap dump)检测期间操作设备完成后点击Stop按钮检测结束后显示有内存泄漏及内存泄漏的数目 如何查看内存泄漏的位置 双击内存泄漏的位置显示内存泄漏的列表 点击列表中其中一个显示实例对象 点击实例对象显示详细信息 切换到References选项卡并点击show nearest GC root only 右键选择jump to source 跳转到源码可以看到是thread引起的内存泄漏
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/85085.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!