单例模式的简单描述(饿汉式,饱汉式,双重锁模式)

一、什么时候使用单例模式:

当实例存在多个会引起程序逻辑错误的时候

二、好处:

1、减少内存的占用2、单例模式会阻止其他对象实例化其自己的单例对象的副本,从而确保所有对象都访问唯一实例。3、因为类控制了实例化过程,所以类可以灵活更改实例化过程

三、缺点:1、开销虽然数量很少,但如果每次对象请求引用时都要检查是否存在类的实例,将仍然需要一些开销。可以通过使用静态初始化解决此问题。2、可能的开发混淆使用单例对象(尤其在类库中定义的对象)时,开发人员必须记住自己不能使用new关键字实例化对象。因为可能无法访问库源代码,,因此应用程序开发人员可能会意外发现自己无法直接实例化此类。3、对象生存期不能解决删除单个对象的问题。在提供内存管理的语言中(例如基于.NET Framework的语言),只有单例类能够导致实例被取消分配,因为它包含对该实例的私有引用。在某些语言中(如 C++),其他类可以删除对象实例,但这样会导致单例类中出现悬浮引用。

四、单例模式的三种模式:

1、饱汉式

public class SingletonDemo{private static SingletonDemo instance = null;private SingletonDemo(){}public SingletonDemo getInstance(){if(instance==null){instance = new SingletonDemo();}return instance;}}

2、饿汉式

public class SingletonDemo{private static SingletonDemo instance = new SingletonDemo();private SingletonDemo(){}public SingletonDemo getInstance(){return instance;}}

3、双重锁形式

这个模式将同步内容下方到if内部,提高了执行的效率,不必每次获取对象时都进行同步,只有第一次才同步,创建了以后就没必要了。

public class SingletonDemo {private static SingletonDemo instance = null;private SingletonDemo(){}public static SingletonDemo getInstance(){if(instance==null){synchronized(SingletonDemo.class){if(instance==null){instance = new SingletonDemo();}}}return instance;}}

你有没有这样的感觉,坐在一列火车上,

单例模式的简单描述(饿汉式,饱汉式,双重锁模式)

相关文章:

你感兴趣的文章:

标签云: