Holder方式指静态内部类实现单例,因内部类名为Holder得名,利用JVM类加载机制保证线程安全与懒加载,实例在首次调用getInstance时初始化,无需同步关键字,兼具高效与简洁。
Java单例模式中的“Holder”指的是静态内部类(Static Inner Class)实现方式中的 Holder 类,常被称为
“Holder 方式”或“静态内部类单例”。它是一种既保证线程安全、又实现懒加载(延迟初始化)的优雅单例写法。
这个名称来源于它的典型结构:外部类中定义一个静态内部类,名字常取为 Holder(也可叫 SingletonHolder 等),该内部类里声明并初始化单例实例。JVM 保证静态内部类的初始化是线程安全的,且只在首次主动使用时触发 —— 这正是实现懒加载的关键。
常见代码结构如下:
public class Singleton {
private Singleton() {} // 私有构造
private static class Holder {
static final Singleton INSTANCE = new Singleton();
}
public static Singleton getInstance() {
return Holder.INSTANCE;
}
}
调用 getInstance() 时,才首次触发 Holder 类的初始化,从而创建实例。JVM 类加载机制天然保证该过程线程安全,无需 synchronized 或 volatile。
getInstance() 时才创建,不是类加载时就初始化readResolve() 可进一步加固(但 Holder 本身不解决反序列化问题)基本上就这些。Holder 方式是 Java 单例实践中被广泛推荐的写法之一,兼顾了安全性、延迟性和可读性。