在Android开发过程当中,咱们常常碰到的状况就是在咱们不清楚为何状况下,程序忽然出现Crash了。其中有一类日志相信你们都常常碰到过,这类日志就是OOM相关的日志。这类日志除了咱们知道的Bitmap操做的时候会常常致使,还有一种隐藏的较深的缘由就是内存泄露(Memory Leak)。编辑器
推荐使用 LeakCanary 工具来检测应用程序是否存在内存泄露。LeakCanary是由 Square 开源的一款轻量级的第三方内存泄漏检测工具,当检测到程序中产生内存泄漏时,它将以最直观的方式告诉咱们哪里产生了内存泄漏和致使谁泄漏了而不能被回收。工具
单例的静态特性使得其生命周期和应用的生命周期同样长。
如图,咱们先声明一个单例对象:
而后在Activity使用的时候,习惯性的传一个this:
集成了LeakCanary后测试,发现内存泄露了:
解决方案:
通常状况下,改为以下图的写法就能够了,由于单例的生命周期和应用的同样长,这样就防止了内存泄漏。:
总结:单例模式形成泄漏的缘由是拥有更长生命周期的对象持有短生命周期对象的强引用。测试
通常状况下,容易产生内存泄露的资源主要为:File,Cursor,Stream,Bitmap,BroadcastReceiver等,这些资源在使用时建议及时关闭,不然当这些资源没有及时回收的时候,内存泄露也就产生了。针对这些资源使用,给以下建议:this
在咱们使用Handler的时候,常常看到编辑器提示咱们Handler可能会形成内存泄露,通常在这种状况下,咱们能够将Handler独立出来或者使用静态内部类,这样能够避免内存泄露。
这样作的缘由是:非静态内部类会潜在的持有它所属的外部类的引用,可是静态内部类是不会的。日志
咱们可使用WeakReference来规避好多潜在的内存泄露的问题,可是并不代表WeakReference就是解决内存泄露的金钥匙。是否使用WeakReference主要取决于对当前对问题的理解,这须要咱们对问题的的建模思想。对象