单例模式

//1.单例模式的通用代码
public class Singleton{
    private static final Singleton singleton=new Singleton();
    private Singleton(){}
    
    public static Singleton getSingleton(){
        return singleton;
    }
    //类中的其他方法
}

//2.线程不安全的单例模式
public class Singleton{
    private static final Singleton singleton=null;
    private Singleton(){}
    //通过该方法获取实例对象
    public static Singleton getSingleton(){
        if(singleton==null){
            singleton=new Singleton();
        }
        return singleton;
    }
    //类中的其他方法
}

第二钟单例模式当系统压力增大,并发量增加时则可能在内存中出项多个实例,破坏了最初的预期。出现这种情况是因为如果一个线程A执行到
singleton=new Singleton(),但是还没有获得对象(对象初始化是需要使时间的),第二个线程B也在执行,执行到(single==null)
判断,那么线程B获得判断的条件为真,于是继续运行下去,在内存中就会出现两个对象。

其次,在考虑到对象的复制情况下。在Java中,对象默认是不可以被复制的,若实现了Cloneable接口,并实现了clone方法,则可以直接通过
对象复制方式创建一个新的对象,对象复制是不用调用类的构造函数,因此即使是私有的构造函数,对象仍然可以被复制。在一般情况下,类
复制的情况不需要考虑,很少会出现一个单例类会主动要求被被复制的情况,解决该问题的最好方法就是单例类不要实现Cloneable接口。

原文地址:https://www.cnblogs.com/liaojie970/p/5458982.html