//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接口。