饿汉式:线程安全
缺点:加载类后一开始就被初始化,即使客户端没有调用getInstance()方法。
饿汉式的创建方式在一些场景中将无法使用:譬如 Singleton 实例的创建是依赖参数或者配置文件的,在 getInstance() 之前必须调用某个方法设置参数给它,那样这种单例写法就无法使用了。
package com.pn.thread;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Singleton {
// static ExecutorService pool = Executors.newCachedThreadPool();
private Singleton() {
}
private static Singleton singleton = new Singleton();
public static Singleton getInstance() {
return singleton;
}
public static void main(String[] args) {
for (int i = 0; i < 1000; i++) {
// pool.execute(()->{System.out.println(Singleton.getInstance().hashCode());});
new Thread(() -> {System.out.println(Singleton.getInstance().hashCode());}, String.valueOf(i)).start();
}
}
}
main 方法启动之后,console全部输出 410370156 证明是单例且线程安全的。