LeakCanary
Github 地址:https://github.com/square/leakcanary

集成方案:
在 moduleName(不是Project)/build.gradle中的
dependencies {
}
方法内添加代码
debugCompile ‘com.squareup.leakcanary:leakcanary-android:1.5.1’
releaseCompile ‘com.squareup.leakcanary:leakcanary-android-no-op:1.5.1’
testCompile ‘com.squareup.leakcanary:leakcanary-android-no-op:1.5.1’
在当前自定义Application extends Application 中的 onCreate()方法中添加
if (LeakCanary.isInAnalyzerProcess(this)) {
// This process is dedicated to LeakCanary for heap analysis.
// You should not init your app in this process.
return;
}
LeakCanary.install(this);
重新build 应用。让程序跑一会。

LeakCanary 实例分析
下边是我自己造的一个大的内存泄露
直接上图
LeakCanary简单介绍

我自Activity-A 中造了一个内存泄露,
finish 后的Activity 在 接近一分钟的时间gc没有回收它。
LeakCanary 在手机上显示的图如下图所示:
LeakCanary简单介绍
它说MainApplication 中 static 参数 activityList 持有已finish 掉的Activity-A 的对象造成47M内存泄露(在标题栏上没有显示全部)
然后就开始根据这个信息去改进。现在不让MainApplication 中activityList 不持有 Activity-A的对象。看内存变化的图片
下图所示:
LeakCanary简单介绍

很明显从原来的80+M的内存占有量降到40+M的内存占有量。

以上就是使用 LeakCanary 工具分析并解决内存的一个简单的示例。希望对大家有所帮助

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-12-02
  • 2021-11-30
  • 2021-11-17
  • 2021-11-19
  • 2021-11-22
  • 2021-11-23
猜你喜欢
  • 2021-09-13
  • 2022-12-23
  • 2021-07-09
  • 2021-07-14
  • 2022-12-23
  • 2021-12-17
相关资源
相似解决方案