内存泄漏检测利器--leakcanary实例试玩

以前,我们测试内存泄漏是这样的:
1.打开android studio的内存监控,重复进入退出模块然后看内存
2.利用mat的插件去比较分析
现在:
1.利用leakcanary工具直接注入,然后默默等待…

这个开源工具的地址:https://github.com/square/leakcanary

好了,接下来开始试玩了,leakcanary的使用非常简单,在build.gradle中添加依赖包

debugCompile 'com.squareup.leakcanary:leakcanary-android:1.4-beta2'
   releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.4-beta2'
   testCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.4-beta2'

然后在你自己的application类当中的onCreate方法加入

public class MyApplication extends Application {

    @Override
    public void onCreate() {
        super.onCreate();
        LeakCanary.install(this);
    }
}

嗯,没了,就是这样,深入的使用方法以后有空再研究吧,不过这样已经可以定位到问题了,下面是自己构造的泄漏的代码:

下面是构造一个大的activity,并注册在一个静态

package com.cloudhuan.memorytest;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

import java.util.ArrayList;
import java.util.List;

public class Main2Activity extends AppCompatActivity {

    List<Object> l;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
        l = new ArrayList<>();
        for(int i = 0;i<10000;i++){
            l.add(new Object());
        }
        Log.v("ch","------------>"+l.size());
        MyActivityManager.registActivity(this);
    }
}

声明的一个管理类,持续持有对象

package com.cloudhuan.memorytest;

import android.app.Activity;

import java.util.ArrayList;

/**
 * Created by cloudhuan on 2016/5/15.
 */
public class MyActivityManager {

    static ArrayList arrayList = new ArrayList();

    public static void registActivity(Activity activity){
        arrayList.add(activity);
    }

    public static void unregistActivity(Activity activity)  {
        arrayList.remove(activity);
    }
}

好了,开始运行,每次点击按钮后返回,gc,多次操作的内存图如下:
这里写图片描述
太明显了…

最后是运行的界面图以及多次操作后的泄漏图
这里写图片描述
这里写图片描述
那么重点关注结果图,最后的红点表示的是Main2Activity实例泄漏的,而上面几个是跟踪过程,可以看到最后定位到的是arrayList这个容器有泄漏,然后就可以走查代码了

static ArrayList arrayList = new ArrayList();

也就是定位到上面这行,也就能发现问题了,解决方法是这样的,非常通用,在onDestory反注册就完了:

 @Override
    protected void onDestroy() {
        super.onDestroy();
        MyActivityManager.unregistActivity(this);
    }

然后在此运行:
这里写图片描述
ok,完美解决,leakcanary确实是神器 :) 目前已经在我们项目中使用了 效果棒棒的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值