android 内存泄漏代码,浅谈Android内存泄漏

AAffA0nNPuCLAAAAAElFTkSuQmCC

内存泄漏:是指内存得不到GC的及时回收,从而造成内存占用过多,从而导致程序Crash,也就是常说的OOM。

一、static

先来看下面一段代码

public class DBHelper {

private static DBHelper db= null;

private DBHelper() {

}

public static DBHelper getInstance(Context context) {

if (bitmapUtils == null) {

synchronized (DBHelper.class) {

if (db== null) {

db= new db(context,DBNAME);

}

}

}

return db;

}

}

这样的代码在项目中很常见,如果大家仔细一点,应该能发现问题在那里。helper中持有了context的应用,而DBHelper是全局的,也就是说,当在一个Activity中使用了DBHelper,即使这个Activity退出了,这个Activity也没法被GC回收,从而造成Activity一直驻留在内存中。

这个解决方案也比较简单,代码如下

public class DBHelper {

private static DBHelper db= null;

private DBHelper() {

}

public static DBHelper getInstance(Context context) {

if (bitmapUtils == null) {

synchronized (DBHelper.class) {

if (db== null) {

db= new db(context.getApplicationContext(),DBNAME);

}

}

}

return db;

}

}

只需要把context改成ApplicationContext()即可,因为ApplicationContext本身就是全局的。

二、非静态内部类、Handler

先来看一段代码

private Handler handler = new Handler(){

@Override

public void dispatchMessage(Message msg) {

// 消息处理

}

};

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

new Thread(new Runnable() {

@Override

public void run() {

// 耗时操作

handler.sendEmptyMessage(1);

}

}).start();

}

我们知道非静态内部类会持有外部类的引用,此时这里的Handler持有着外部Activity的引用,当我们在Activity的内部类中进行异步耗时操作时,我们的Activity如果此时被finish掉了,而异步任务没有执行结束,这就会导致我们的Activity对象不能及时的被GC回收,从而导致内存问题。

这样的问题解决起来也很简单

不要在匿名内部类中进行异步操作

使用静态匿名内部类

总结:内存问题大多数都是因为对对象生命周期的不巧当处理造成的,在使用某个对象时,我们需要仔细研究对象的生命周期,当处理一些占用内存较大并且生命周期较长的对象时,应用使用软引用对其就行处理,及时关闭不使用的资源。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值