美文网首页
Android内存泄漏(三):单例

Android内存泄漏(三):单例

作者: meixinxicun | 来源:发表于2017-03-22 15:44 被阅读891次

上一节我们介绍了关于匿名内部类的内存泄漏,这一节我们来看一下单例产生内存泄漏的情况

知识点

单例的生命周期和应用(Application)的生命周期一样长

案例

我们先来看一段代码

public class GlobalManager {
    private volatile static GlobalManager instance;
    private Context mContext;

    private GlobalManager(Context context) {
        this.mContext = context;
    }

    public static GlobalManager getInstance(Context context) {
        if (instance == null) {
            synchronized (GlobalManager.class) {
                if (instance == null) {
                    instance = new GlobalManager(context);
                }
            }
        }
        return instance;
    }
}

这段代码中,单例的生命周期和Application是一样的。
我们看看activity的使用:

public class TestAct extends AppCompatActivity {
    private static GlobalManager globalManager = null;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.act_test);
        if (globalManager == null) {
            globalManager = GlobalManager.getInstance(this);
        }
    }
}

我们来分析一下这段代码:
globalManager = GlobalManager.getInstance(this),这里传入的是Activity的Context,当此Activity退出时,Activity应该被回收,可是这个单例持有这个activity的强引用,导致回收失败,所以造成内存泄漏。

解决方法

我们不管传入的是Context还是ApplicationContext,我们都将它转换为ApplicationContext,这样这个单例就不会持有Activity或其他Context的强引用了。单例代码修改如下

public class GlobalManager {
    private volatile static GlobalManager instance;
    private Context mContext;

    private GlobalManager(Context context) {
        this.mContext = context.getApplicationContext();
    }

    public static GlobalManager getInstance(Context context) {
        if (instance == null) {
            synchronized (GlobalManager.class) {
                if (instance == null) {
                    instance = new GlobalManager(context);
                }
            }
        }
        return instance;
    }
}

只是修改了构造方法:讲this.mContext = context;改成了this.mContext = context.getApplicationContext();,不管传入什么Context最终将使用Application的Context

ok,单例的内存泄漏情况我们就介绍这么多,下一节介绍非静态内部类作为静态变量造成的内存泄漏情况。

上一节:Android内存泄漏(二):匿名类
下一节:Android内存泄漏(四):非静态内部类作为静态变量

相关文章

  • Android 常见内存泄漏

    一、单例造成的内存泄漏Android的单例模式非常受开发者的喜爱,不过使用的不恰当的话也会造成内存泄漏。因为单例的...

  • Android内存泄漏(三):单例

    上一节我们介绍了关于匿名内部类的内存泄漏,这一节我们来看一下单例产生内存泄漏的情况 知识点 单例的生命周期和应用(...

  • Android内存泄漏之集合类

    Android内存泄漏基本可以分为以下四大类:1、集合类泄漏2、单例/静态变量造成的内存泄漏3、匿名内部类/非静态...

  • Android内存优化之内存泄漏

    内存泄漏 内存泄漏一般有以下几种情况:单例、静态变量、Handler、匿名内部类、资源使用未关闭 单例导致的内存泄...

  • 何止学习Andoid内存泄漏优化

    一、Android内存泄露及优化 1、单例模式造成内存泄漏 单例的静态特性使得它的生命周期同应用的生命周期一样长,...

  • Android 容易引起内存泄漏的小知识

    android单例模式引起的内存泄漏 当我们在使用单例模式保存缓存时,一般会把当前页面的上下文Context传入单...

  • 使用ConnectivityManager的内存泄漏隐患

    Android里面内存泄漏问题最突出的就是Activity的泄漏,而泄漏的根源大多在于单例的使用,也就是一个静态实...

  • Android内存优化——常见内存泄露及优化方案

    内存泄漏情况分类 1、单例模式导致内存泄漏 2、静态变量导致内存泄漏 3、非静态内部类导致的内存泄漏 4、未取消注...

  • Android性能-内存泄漏

    泄漏原因: 单例造成的内存泄漏 非静态内部类(匿名类等)创建静态实例造成的内存泄漏 Handler/Thread/...

  • 常见的内存泄漏(转载)

    一、静态变量持有 二、单例模式造成 三、非静态内部类创建静态实例可能造成的内存泄漏 四、webview造成内存泄漏...

网友评论

      本文标题:Android内存泄漏(三):单例

      本文链接:https://www.haomeiwen.com/subject/uxmonttx.html