登录
首页 >  文章 >  java教程

静态内部类单例模式实现解析

时间:2026-04-21 23:30:52 184浏览 收藏

静态内部类单例模式巧妙利用JVM类加载机制,在不依赖同步关键字或双重检查锁的前提下,天然实现懒加载与线程安全:外部类加载时内部类不初始化,仅在首次调用getInstance()时触发SingletonHolder类的加载与静态字段初始化,从而创建并返回唯一实例;它结构简洁、性能优越、无反射攻击风险(配合私有构造),是Java中推荐的高效单例实现方式之一,尤其适合无参初始化场景。

静态内部类实战:怎么声明Static内部类实现单例模式设计

静态内部类实现单例模式,核心在于利用类加载机制保证线程安全与懒加载——外部类加载时,静态内部类不被加载;只有首次调用 getInstance() 时,JVM 才初始化该静态内部类,从而创建唯一实例。

怎么声明静态内部类

静态内部类用 static 修饰,它不持有外部类的引用,可独立于外部类实例存在。声明时需注意:

  • 必须用 static 关键字修饰内部类(不能是普通内部类)
  • 静态内部类中定义的单例实例也必须是 static final(或仅 static,配合私有构造)
  • 外部类通常将构造方法设为 private,禁止外部 new 实例

完整代码示例

以下是一个标准、可直接使用的静态内部类单例写法:

public class Singleton {
    // 私有构造,防止外部实例化
    private Singleton() {}

    // 静态内部类,持有单例实例
    private static class SingletonHolder {
        private static final Singleton INSTANCE = new Singleton();
    }

    // 全局访问点,懒加载 + 线程安全
    public static Singleton getInstance() {
        return SingletonHolder.INSTANCE;
    }
}

调用方式:Singleton.getInstance()。第一次调用时触发 SingletonHolder 类加载和初始化,后续直接返回已创建的实例。

为什么它既懒加载又线程安全

JVM 对类初始化过程有严格规范:

  • 懒加载:外部类 Singleton 加载时,SingletonHolder 不加载;直到 getInstance() 中首次引用它,才触发初始化
  • 线程安全:JVM 保证一个类的 (类构造器)只执行一次,且由类加载器加锁同步,天然线程安全,无需 synchronized 或双重检查锁

注意事项与常见误区

  • 不要把内部类写成非静态(即去掉 static),否则会隐式持外部类引用,且无法在静态方法中直接访问
  • 不要在 SingletonHolder 外部提前引用该类(如静态字段赋值时 new 它),否则破坏懒加载
  • 如果单例需要依赖参数初始化(如配置项),静态内部类方式不适用,应改用枚举或带参数的工厂方法
  • 反序列化可能破坏单例,如需防御,可添加 readResolve() 方法

今天关于《静态内部类单例模式实现解析》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>