谈到单例模式,首先需要说明一下,单例模式(Singleton Pattern)是JAVA中最简单的设计模式之一。这种类型的设计模式属于创建型模式。保证一个类仅有一个实例,并提供一个访问它的全局访问点。
要实现一个线程安全的单例模式有多种做法。常见的有懒汉式、饿汉式、双检锁/双重校验锁、静态内部类、枚举等方式。每种方式都有优缺点,并不偏向某一种创建方式。具体情况具体分析,然后采用比较好的创建方式才是最明智的选择。
在这里我采用双检锁/双重校验锁方式来创建一个线程安全的单例模式。
package com.singleton;
import java.util.Arrays;
/**
* 线程安全的单例模式
* 双检锁/双重校验锁,volatile关键字一定要加,不然在会存在多线程并发时候可能返回半初始化对象
* 详情可以在我的头条号 ‘小辉GE’ 查看对应单例模式视频,里面有详细讲解
*
* @author 小辉GE/小辉哥
* <p>
* 2019年8月7日 下午21:30:00
*/
public class Singleton {
private static volatile Singleton single = null;
private Singleton() {
}
public static Singleton getInstance() {
if (single == null) {
synchronized (Singleton.class) {
if (single == null) {
single = new Singleton();
}
}
}
return single;
}
public static void main(String[] args) {
Thread[] th = new Thread[100];
for (int i = 0; i < th.length; i++) {
th[i] = new Thread(() -> {
System.out.println(Singleton.getInstance().hashCode());
});
}
Arrays.asList(th).forEach(o -> o.start());
}
}
测试输出结果如下(输出结果比较多,我们只截取部分):
关于双检锁/双重校验锁创建方式为什么需要volatile,详情可以在我的头条号‘小辉GE’查看对应单例模式视频,里面有详细讲解
以上代码仅供参考,如有不当之处,欢迎指出!!!
更多干货,欢迎大家关注和联系我。期待和大家一起更好的交流、探讨技术!!!