[置顶] 高并发下线程安全的单例模式(最全最经典)
http://blog.csdn.net/cselmu9/article/details/51366946
单例模式
功能:保证类在运行期间只会被创建一个类实例。
单例模式是对象的创建模式之一,此外还包括工厂模式。单例模式有如下几个特点:
1:该类只有一个实例。
2:该类自行创建该实例,在该类内部创建自身的实例对象。
3:向整个系统公开这个实例接口。
例如下面代码演示:
package com.wbx.design;
import test.C;
public class Singleton {
//私有,静态的类自身实例
private static Singleton instance = new Singleton();
//私有构造函数
private Singleton(){ //2:构造函数
System.out.println("aaaaaaaaa");
}
//公开,静态的工厂方法
public static Singleton getInstance(){ //3
System.out.println("bbbb");
return instance;
}
C c = new C(); //1:属性类的构造函数
}
上面代码片段中引入创建对象C,为了看看类中代码的执行顺序。
测试单例模式在内存中只有一个实例
public static void main(String[] args) {
Singleton s1 = getInstance();
Singleton s2 = getInstance();
Singleton s3 = getInstance();
System.out.println("s1=="+s1);
System.out.println("s2=="+s2);
System.out.println("s3=="+s3);
C c1 = new C(); //1:属性类的构造函数
C c2 = new C(); //1:属性类的构造函数
C c3 = new C(); //1:属性类的构造函数
System.out.println("c1=="+c1);
System.out.println("c2=="+c2);
System.out.println("c3=="+c3);
}
测试结果
ccccccccccc
aaaaaaaaa
bbbb
bbbb
bbbb
s1==com.wbx.design.Singleton@2f581b9f
s2==com.wbx.design.Singleton@2f581b9f
s3==com.wbx.design.Singleton@2f581b9f
ccccccccccc
ccccccccccc
ccccccccccc
c1==test.C@417d7c01
c2==test.C@1558473e
c3==test.C@56ad4264
单例模式的优点和缺点
1:优点
a:减少内存消耗,特别是一个对象如果频繁地创建、销毁,而且创建或销毁时性能无法优化,这时采用单例模式的优势就非常明显。
b:当一个对象产生需要比较多的资源时,如读取配置、产生其他对象时,则可以通过在应用启动时直接产生一个对象,然后永久驻留内存的方式来解决(在Java EE中采用单例模式时需要注意JVM垃圾回收机制);
c:单例模式可以在系统中设置全局的访问点,优化共享资源的访问,例如可以设计一个单例类,负责所有数据表的映射处理。
2:缺点
a:单例模式没有接口,扩展很困难,接口对单例模式是没有任何意义,它要求“自行实例化”,并且提供单一实例、接口或抽象类是不可能被实例话的。
b:单例模式与单一职责原则有冲突。一个类应该只实现一个的逻辑,而不关系它是否是单例的,决定它是不是要单例是环境决定的,单例模式把“要单例”和业务逻辑融合在一个类中。