Android实战——LeakCanary检测内存泄漏


本篇文章包括以下内容:

  • 前言
  • 内存泄漏的简介
  • 内存溢出的简介
  • LeakCanary的配置与使用
  • 结语

内存泄漏对于初学者们可能是一个陌生的词语,但是却频频发生于自己的软件上,只不过自己不知道而已。同理,内存溢出也是一个道理。而内存泄漏和内存溢出常常是面试的考题,所以早点掌握是必不可少的

内存泄漏是指:对象在它有限的生命周期结束时,它们将被垃圾回收,如果在回收时,这个对象还被一系列的引用,导致该对象不会被回收,那么就会导致内存泄漏。随着泄漏的累积,应用将消耗完内存,应用的流畅性就会大大减弱

常见的内存泄漏有:

  1. 静态变量引用导致内存泄漏
  2. 属性动画未及时关闭导致的内存泄漏

涉及到内存泄漏,当然也逃不过内存溢出的内容

内存溢出是指:程序要求的内存,超出了系统所能分配的范围,从而发生溢出。Android应用程序的默认最大内存值为16M,如果你使用的内存超过最大值,则会导致应用报错

常见的内存溢出有:

  1. 图片过大导致内存溢出

LeakCanary是square公司开发出来的检测内存泄漏的神器,他可以嵌入到我们的应用中,帮助我们自动检测内存泄漏

在项目的gradle中添加对LeakCanary的依赖

首先,需要创建一个类继承自Application,为了让我们LeakCanary在全局的Activity中能够起作用

接着,在Manifests文件中指定该Application

最后,就是在Application中直接配置我们的LeakCanary

到此我们的LeakCanary就已经嵌入成功,就剩测试了

我们采用静态变量的内存泄漏来作为我们的测试结果,创建一个类,该类的作用可以保存一个Activity对象到一个ArrayList中,让Activity一直存在

做好了内存泄漏类之后,就在我们的主界面中直接使用该类,并将主界面的Activity存放在ArrayList中

这个时候,我们就已经模拟了内存泄漏了,接着,就可以运行程序进行测试了

我们运行程序进入主界面,那么主界面的Activity就被保存起来了,军训心得这个时候是没什么事情的,因为主界面的Activity还被引用,并不会发生内存泄漏。接着,我们退出主界面,按道理是:退出主界面Activity,其生命周期就被结束了,该Activity必须被系统回收,但是我们还留了一手,将它保存起来了,那么等待一段时间后,就会在通知栏收到LeakCanary的通知信息

这个时候,内存泄漏报告就出来了,点击通知信息,进入内存泄漏报告分析

结果分析得:

第一部分(ActivityPool类的activities变量)由于第二部分(ArrayList中的某个数组)和第三部分(数组中的某个对象) 导致第四部分(LeakCanaryActivity类的实例instance)泄露

这样我们就可以很容易的定位到内存泄漏的部分

上面说到为什么要在关闭Activity时,等待一段时间才会出现内存泄漏报告呢?

原因是:LeakCanary会监听所有Activity的生命周期,并且在Activity的onDestory函数结束后,将该Activity添加到内存泄漏监控队列中。接着,在后台线程中检测这个引用是否被清除,如果没有将会发生GC操作(垃圾回收),如果引用仍然没有清除,将heap内存dump到一个.hprof文件并存放在手机系统里,应用会开启另一个进程来分析该.hprof文件,最后导出泄漏引用链,传回应用程序中,通过推送推送出信息

LeakCanary的使用并不难,重要的是如何排除内存泄漏的问题,可能大部分问题还是需要在实战中才能摸索出来,这里只是举一例子,不过通过这篇之后,相信你对内存泄漏和溢出都有一个大概的了解,对待类似面试题应该是没什么问题了

原文地址:https://www.cnblogs.com/zhanglixina/p/9603722.html

时间: 2024-08-08 14:00:23

Android实战——LeakCanary检测内存泄漏的相关文章

LeakCanary检测内存泄漏

内存泄漏原因: 线程造成的内存泄漏 Handler造成的内存泄漏 单例导致内存泄露 静态变量导致内存泄露 非静态内部类导致内存泄露 未取消注册(BroadcastReceiver )或回调导致内存泄露 Timer和TimerTask导致内存泄露 集合中的对象未清理造成内存泄露 资源未关闭或释放导致内存泄露 属性动画造成内存泄露 WebView造成内存泄露 添加依赖: implementation 'com.squareup.leakcanary:leakcanary-android:1.6.3'

Android 使用LeakCanary 检测内存泄露

LeakCanary 是 Android 和 Java 内存泄露检测框架,该框架是Square公司的一个开源库,项目地址 leakcanary . Android 开发中你是否频频遇到内存泄露而无奈无从解决.说不定哪天你不小心写的一行代码就导致了内存泄露.可以先看看这些问题导致的内存泄露 Android开发编码规范导致的内存泄露问题,而LeakCanary 则很直白得检测出了内存泄露并展示给我们.在使用它之前,我们来写一个例子. 本地广播,在开发中还是有一定的应用的,现在有这么一个需求,要求使用

Android 性能优化之内存泄漏检测以及内存优化(上)

在 Java 中,内存的分配是由程序完成的,而内存的释放则是由 Garbage Collecation(GC) 完成的,Java/Android 程序员不用像 C/C++ 程序员一样手动调用相关函数来管理内存的分配和释放,虽然方便了很多,但是这也就造成了内存泄漏的可能性,所以记录一下针对 Android 应用的内存泄漏的检测,处理和优化的相关内容,上篇主要会分析 Java/Android 的内存分配以及 GC 的详细分析,中篇会阐述 Android 内存泄漏的检测和内存泄漏的常见产生情景,下篇会

Android性能优化之内存泄漏

综述 内存泄漏(memory leak)是指由于疏忽或错误造成程序未能释放已经不再使用的内存.那么在Android中,当一个对象持有Activity的引用,如果该对象不能被系统回收,那么当这个Activity不再使用时,这个Activity也不会被系统回收,那这么以来便出现了内存泄漏的情况.在应用中内出现一次两次的内存泄漏获取不会出现什么影响,但是在应用长时间使用以后,若是存在大量的Activity无法被GC回收的话,最终会导致OOM的出现.那么我们在这就来分析一下导致内存泄漏的常见因素并且如何

Android开发 |常见的内存泄漏问题及解决办法

在Android开发中,内存泄漏是比较常见的问题,有过一些Android编程经历的童鞋应该都遇到过,但为什么会出现内存泄漏呢?内存泄漏又有什么影响呢? 在Android程序开发中,当一个对象已经不需要再使用了,本该被回收时,而另外一个正在使用的对象持有它的引用从而导致它不能被回收,这就导致本该被回收的对象不能被回收而停留在堆内存中,内存泄漏就产生了. 内存泄漏有什么影响呢?它是造成应用程序OOM的主要原因之一.由于Android系统为每个应用程序分配的内存有限,当一个应用中产生的内存泄漏比较多时

Linux/Unix用valgrind检测内存泄漏

c\c++编程中,内存管理是比较头疼的问题,一不小心就会造成内存泄漏,除了养成良好的编程习惯外(使用智能指针等),使用工具也能帮助检测内存泄漏,valgrind是Unix\Linux下一款不错的工具.(mac下暂时有bug) Valgrind 安装 到www.valgrind.org下载最新版valgrind-3.2.3.tar.bz2 解压安装包:tar –jxvf valgrind-3.2.3.tar.bz2 解压后生成目录valgrind-3.2.3 cd valgrind-3.2.3 运

xcode里面使用Memory Leaks和Instruments检测内存泄漏

教程截图: Leaks和Instruments教程[检测内存泄露]" src="http://pic002.cnblogs.com/images/2011/283130/2011080816513182.jpg"> 作为一名无证程序员,无论你多么精通Objective-C的内存管理,随着时间的推移,你也不可避免的犯内存相关的错误.但通常因为代码量太大,以至于你不可能一行一行的去排除(等你解决完,你设计的动车早相撞了!) 幸运的是,苹果已经提供了一些好的方式来帮助你找到应

Qt creator 搭配 valgrind 检测内存泄漏

继上次重载operator new检测内存泄漏失败之后,妥协了.决定不管是否是准确指明哪一行代码出现内存泄漏,只要告诉我是否有泄漏就行了,这样就没有new替换的问题.在开发中,总是一个个小功能的开发.如果开发完一个小功能告诉我有内存泄漏,那想必也是比较容易找的. 这次的想法是重写operator new,然后每次new的时候记录一下地址及申请内存的大小,释放时删除记录.这样,程序结束时剩余的记录就是泄漏的了.记录的数据结构首选STL的map.结果,在记录时,map需要申请内存,调用new,new

Android中常见的内存泄漏

为什么会产生内存泄漏? 当一个对象已经不需要再使用了,本该被回收时,而有另外一个正在使用的对象持有它的引用从而导致它不能被回收,这导致本该被回收的对象不能被回收而停留在堆内存中,这就产生了内存泄漏. 内存泄漏对程序的影响? 内存泄漏是造成应用程序OOM的主要原因之一!我们知道Android系统为每个应用程序分配的内存有限,而当一个应用中产生的内存泄漏比较多时,这就难免会导致应用所需要的内存超过这个系统分配的内存限额,这就造成了内存溢出而导致应用Crash. Android中常见的内存泄漏汇总 1