Mango 2012-03-28
Android下的内存泄漏很隐晦
(1)不同的引用类型:
Java2平台里面引入了java.lang.ref包,这个包中的类可以让我们引用对象,但这些对象可以不用停留在内存中。这些引用类和Java本身的垃圾回收器还存在一定的交互(在垃圾回收的不同阶段)。Java对引用的分类(Strong reference, SoftReference, WeakReference, PhatomReference):
级别 | 什么时候被垃圾回收 | 用途 | 生存时间 |
强 | 从来不会 | 对象的一般状态 | JVM停止运行时终止 |
软 | 在内存不足时 | 对象简单?缓存 | 内存不足时终止 |
弱 | 在垃圾回收时 | 对象缓存 | gc运行后终止 |
假象 | Unknown | Unknown | Unknown |
(2)Android下怎样避免内存泄漏?
Refer:http://android-developers.blogspot.com/2009/01/avoiding-memory-leaks.html
有人问:static的Drawable在被重新链入一个TextView后,其callback是否也被重置,即原来的callback被丢弃呢?如果不,Android的实现好像有问题哟!
(3)如何查找内存泄漏:
refer:http://www.cnblogs.com/lbeing/archive/2010/09/29/1838858.html
如何用MemoryAnalyzerTool(MAT)来分析,前提是Android开发和测试的工具安装完整,SDK,Eclipse.
更多关于MAT的内容,refer:
http://blog.csdn.net/studyvcmfc/archive/2010/06/05/5649431.aspx
http://itnewsvendor.appspot.com/1780002-使用_memory_analyzer.html
1).打开Eclipse
2).选择Help->InstallNewSoftware;
3).在Workwith中添加站点:http://download.eclipse.org/mat/1.0/update-site/(这个地址可能会变化,但是新的地址可以在官方网站上找到:http://www.eclipse.org/mat/downloads.php)
4).生成.hprof文件:插入SD卡(Android机器很多程序都需要插入SD卡),并将设备连接到PC,在Eclipse中的DDMS中选择要测试的进程,然后点击UpdateHeap和DumpHPROFfile两个Button。
.hprof文件会自动保存在SD卡上,把.hprof文件拷贝到PC上的\android-sdk-windows\tools目录下。这个由DDMS生成的文件不能直接在MAT打开,需要转换。
运行cmd打开命令行,cd到\android-sdk-windows\tools所在目录,并输入命令hprof-convxxxxx.hprofyyyyy.hprof,其中xxxxx.hprof为原始文件,yyyyy.hprof为转换过后的文件。转换过后的文件自动放在android-sdk-windows\tools目录下。
OK,到此为止,.hprof文件处理完毕,可以用来分析内存泄露情况了。
5).打开MAT:
在Eclipse中点击Windows->OpenPerspective->Other->MemoryAnalysis
6).导入.hprof文件
在MAT中点击File->OpenFile,浏览到刚刚转换而得到的.hprof文件,并Cancel掉自动生成报告,点击DominatorTree,并按Package分组,选择自己所定义的Package类点右键,在弹出菜单中选择Listobjects->Withincomingreferences。
这时会列出所有可疑类,右键点击某一项,并选择Path to GC Roots->exclude weak/soft references,会进一步筛选出跟程序相关的所有有内存泄露的类。据此,可以追踪到代码中的某一个产生泄露的类。