Android垃圾回收机制解决内存泄露问题

2019-12-10 19:11:05丽君
易采站长站为您分析Android垃圾回收机制解决内存泄露问题的相关资料,需要的朋友可以参考下  

在android编码中,会有一些简便的写法和编码习惯,会导致我们的代码有很多内存泄露的问题,在这里做一个已知错误的总结:
1、编写单例的时候常出现的错误。

错误方式:

 public class Foo{

   private static Foo foo;

   private Context mContext;

   private Foo(Context mContext){

    this.mContext = mContext;

   }

   // 普通单例,非线程安全

   public static Foo getInstance(Context mContext){

    if(foo == null)

     foo = new Foo(mContext);

    return foo;

   }

   public void otherAction(){

    mContext.xxxx();

    ….

   }

  }

错误原因:

     如果我们在Activity A中或者其他地方使用Foo.getInstance()时,我们总是会顺手写一个『this』或者『mContext』(这个变量也是指向this)。试想一下,当前我们所用的Foo是单例,意味着被初始化后会一直存在与内存中,以方便我们以后调用的时候不会在此次创建Foo对象。但Foo中的『mContext』变量一直都会持有Activity A中的『Context』,导致Activity A即使执行了onDestroy方法,也不能够将自己销毁。但『applicationContext』就不同了,它一直伴随着我们应用存在(中途也可能会被销毁,但也会自动reCreate),所以就不用担心Foo中的『mContext』会持有某Activity的引用,让其无法销毁。

正确方式:   

 public class Foo{

   private static Foo foo;

   private Context mContext;

   private Foo(Context mContext){

    this.mContext = mContext;

   }

   // 普通单例,非线程安全

   public static Foo getInstance(Context mContext){

    if(foo == null)

     foo = new Foo(mContext.getApplicationContext());

    return foo;

   }

   public void otherAction(){

    mContext.xxxx();

    ….

   }

  }