如何使用MAT分析Android应用内存泄露
2016-03-08 · 百度知道合伙人官方认证企业
一、新建测试应用
新建一个Android 测试应用。
添加一个测试Activity:Activity2。
添加测试代码ActivityHelper:
这里用常用的线程长时间执行,导致外部Activity Destroy时还持有 activity的内容导致内存泄露。
主要代码如下:
public class ActivityHelper {
private Context mContext;
public ActivityHelper(Context context) {
this.mContext=context;
}
/** * 打印ActivityName */
public void printActivityName() {
for (int i = 0; i < 100; i++) {
new Thread(new Runnable() {
@Override
public void run() {
while (true)
try {
Thread.sleep(1000*30);
Log.d(ActivityHelper.class.getSimpleName(), ((Activity) mContext).getClass().getSimpleName());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
}
}}
4. 在Activity2中的onCreate方法中调用单例:
new ActivityHelper().printActivityName();
然后再MainActivity中点击“Setting”菜单栏打开Activity2:
Intent intent=new Intent(MainActivity.this,Activity2.class);startActivity(intent);
最后按返回键返回。
按照以上操作,运行程序。
5. 多次进入Activity2之后会发现内存一直在增长,并没有降低。
而且log里会不停的输出log,打印当前activity的name
二、抓取内存信息
1. 点击Android Studio工具栏上得“Android Device Monitor”先在android设备上打开的应用然后在devices里选中测试的应用,点击“update heap”来回点击“settings”进入Activity2数次后,点击“DUMP HPROF file”保存文件。
2. 转换HPROF文件。
利用android sdk 的工具进行转换:
到sdk/platform-tools/目录下,打开终端输入:
./hprof-conv /Users/xxx/Desktop/gc/com.lulee007.androidmemoryleakdemo.hprof /Users/xxx/Desktop/gc/com.lulee007.androidmemoryleakdemo.out.hprof
进行转换.
最终得到这个文件:com.lulee007.androidmemoryleakdemo.out.hprof
3、使用Memory Analyzer 分析
下载Memory Analyzer 工具:选择合适的版本。
打开软件:从工具栏打开phrof文件选择“File”>>"open heap dump"
点击“Action”里的“Histogram”,然后搜索ActivityHelper
右击其中的一个,选择“Merge Shortest Paths to GC Roots ”>>"exclude all phantom/weak/soft etc references.."
可以看到,ActivityHelper本应该被释放,但是因为thead持有其中的mContext,而context是activity2里的,所有造成了内存泄露。
解决方法:
合理用thread,当activity2,destroy时,需要及时的停止掉thread。
可以设置activityhelper的while(true)改为设置变量,如while(notshutdown),
然后再destory里调用activityhelper,设置其notshutdown为false即可。