双重锁检测式(由于JVM底层内部模型关系,偶尔会出现问题。不建议使用)
1.其它和懒汉式一样,只是通过双重检测锁处理后,获取单例的效率更高了步骤
1.私有化构造器
2.提供一个私有的静态的该类对象的引用
3.一个公有的静态的同步方法,返回单例对象(第一次调用该方法时创建单例对象)说明
1.原型是懒汉式,只是不再直接对方法进行加锁,只有第一次调用时才存在同步,从而提高了获取单例对象时的效率
2.但是由于JVM底层内部模型、编译器优化的问题,偶尔会出现问题,不建议使用
测试代码
package top.itcourse.dm;
/**
* 单例模式-双重检测锁:
* 1.构造器私有
* 2.静态的私有的类对象引用
* 3.公有的静态的方法获取单例对象(第一次获取时创建对象)
* 说明:
* 1.这种方式不再直接对方法进行加锁,只有第一次调用时才存在同步,提高了获取单例对象的效率
* 2. 但是由于JVM底层内部模型、编译器优化的问题,偶尔会出现问题,不建议使用
*/
public class SingletonDoubleLock {
// 1.构造器私有
private SingletonDoubleLock() {
}
// 2.静态的私有的对象引用
private static SingletonDoubleLock instance;
// 3.公有的静态的方法获取单例对象(第一次获取时创建对象)
public static SingletonDoubleLock getInstance() {
/**
* 这种方式不直接对方法进行同步,提高了获取单例对象的效率
* 但是由于JVM底层优化的问题,偶尔会出现问题,不建议使用
*/
if(instance == null) {
SingletonDoubleLock sdl;
synchronized (SingletonDoubleLock.class) {
sdl = instance;
if(sdl == null) {
synchronized (SingletonDoubleLock.class) {
if(sdl == null) {
sdl = new SingletonDoubleLock();
}
}
instance = sdl;
}
}
}
return instance;
}
}
其它
源码下载:
关注下方微信公众号,
回复:
DM.code
欢迎加入交流群:451826376
更多信息:www.itcourse.top