一、前言

对于常规意义上的线程使用要及时关闭数据库用完要及时关闭数据用完要及时清空等等这里不再赘述,但是在开发中总会有不熟悉的api开发进度过快,开发人员粗心等等原因导致内存泄露。可以使用leakcanary(参考链接:https://square.github.io/leakcanary/)内存检测处理,或者使用lint(参考链接:https://developer.android.google.cn/studio/write/lint?hl=zhcn)静态代码检测后=,或者开启严格模式StrictMode(参考链接https://developer.android.google.cn/reference/android/os/StrictMode),或者使用Profiler(参考链接:https://developer.android.com/studio/profile/androidprofiler?hl=zh-cn)等等不同的方式进行内存泄露的检查本文记录Profiler进行内存泄露检查的使用方式

需要注意的是本篇文章采用了Android Studio新版的UI进行操作,具体开启方式Preferences->Appearance & Behavior ->New UI然后勾选Enable new UI重启Android Studio开发工具版本

Android Studio Giraffe | 2022.3.1 Patch 4
Build #AI-223.8836.35.2231.11090377, built on November 14, 2023
Runtime version: 17.0.6+0-17.0.6b829.9-10027231 aarch64
VM: OpenJDK 64-Bit Server VM by JetBrains s.r.o.

目前为最新版开发工具
测试工具为红米K60,版本为Android13
如需打开 Profiler 窗口,请依次选择 View > Tool Windows > Profiler,或点击工具栏中的 Profile 图标 在这里插入图片描述

二、内存泄露的排查方式

通过正常启动应用或者通过如下方式启动应用后
在这里插入图片描述
看到如下页面在这里插入图片描述
然后选择Memory选项卡进行双击打开,会看到如下页面
在这里插入图片描述
选择Capture heap dump。然后点击Record进行录制需要功能。这个功能录制完会自动停止,然后停止后的页面如下(这个会自动停止好像跟之前的不太一样,不知道是不是升级后的改动)
在这里插入图片描述
可以看到最上层有Leaks的标志,表示内存泄漏数量。点击位置可以查看内存泄漏的位置
在这里插入图片描述
选择第一个内存泄漏的类双击后,然后保持和如图一直都页面,可以看到内存泄漏路径
在这里插入图片描述
有的信息比较浅显就能看出问题,有的则不能,比如一个问题,暂时不知道该如何排查问题
第二个属于第三方io.github.luoqqsh:immersionbar:3.1.0查看使用方式时候发现其使用方式

ImmersionBar.with(this).init()

方式最终将activity持有在map集合里面,由于声明对象静态类型,所以导致无法释放。暂时这个版本的库没法解决问题
第三个类的问题截图如下:
在这里插入图片描述
这里很好理解就是一个adListener里面的使用不当导致内存泄漏。代码如下
在这里插入图片描述
可以看到在异步加载结束后会更新View,但是加载结束后有可能页面销毁了,但是这里还持有context对象,就会导致内存泄漏。
第四个问题的截图如下:
在这里插入图片描述
没什么有太大价值的信息,只能看出是Fragment添加的时候有问题了,然后查看源码看看没有添加Fragment的操作,好在源码简单,这是一个加载页面,只有一个fragment里面添加了。
在这里插入图片描述
可以看出这个类跟内存泄漏的第五个类是一样的,所以是GoogleNativeInsertAd1Fragment的内存泄漏导致了ScanningFragment的泄漏。查看第五个类的问题
在这里插入图片描述
这里可以看出问题出在了NativeAdView(该控件属于admob的控件)上面,所以是这个控件使用不当导致的问题,顺便注意观察下整个调用链,会发现,这个调用链的顺序是从出现问题的地方逐步往外掉用,也就是说GoogleNativeInsertAd1Fragment中控件导致了这个类泄漏,然后又引发了ScanningFragment的问题,最终导致了Activity的泄漏(这个节点展开)。
至于最后一个的问题如下:
在这里插入图片描述
ReportFragment属于系统类还是隐藏的,不过这种问题也好解决,既然是系统类,那么一定有人已经遇见过了,直接网络搜索一下即可,如下例子:
Android 12原生系统居然有内存泄露隐患?
不过本文不再赘述该问题的解决方式,仅提供一个思路。本文的问题是为如何解决提供一个思路。每个项目逻辑不一样,所以泄漏方式也不一样。能做的只能尽可能去处理这些问题

三、参考链接

  1. 应用性能指南
  2. StrictMode
  3. Android Profiler

原文地址:https://blog.csdn.net/Mr_Tony/article/details/134614266

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_15123.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注