当前位置: 首页 > news >正文

jdk8之后都有什么优化单例的方式

一、基于 ​Lambda 表达式 + Supplier​ 的延迟初始化

利用 Supplier 函数式接口和 ​静态内部类​ 简化延迟加载逻辑:

public class LambdaSingleton {private static final Supplier<LambdaSingleton> INSTANCE = () -> {// 延迟初始化逻辑(线程安全)return Holder.INSTANCE;};private static class Holder {static final LambdaSingleton INSTANCE = new LambdaSingleton();}private LambdaSingleton() {}public static LambdaSingleton getInstance() {return INSTANCE.get();}
}

二、接口静态方法实现饿汉式单例

JDK 8 允许接口定义 ​静态方法,可用于简化饿汉式单例:

public interface ConfigService {ConfigService INSTANCE = new ConfigServiceImpl();static ConfigService getInstance() {return INSTANCE;}// 默认方法(JDK8+)default void loadConfig() {// 配置加载逻辑}
}class ConfigServiceImpl implements ConfigService {// 具体实现
}

三、模块化(JDK9+)​​ 增强单例安全性

通过 Java 模块系统(module-info.java)限制反射访问,防止恶意代码破坏单例:

module com.example.singleton {exports com.example.singleton;  // 仅暴露公共APIopens com.example.singleton.impl to spring.core; // 限制反射访问范围
}

四、VarHandle(JDK9+)​​ 优化双重校验锁

使用 VarHandle 替代 volatile,实现更高效的内存可见性控制:

public class VarHandleSingleton {private static VarHandleSingleton instance;private static final VarHandle INSTANCE_HANDLE;static {try {INSTANCE_HANDLE = MethodHandles.lookup().findStaticVarHandle(VarHandleSingleton.class, "instance", VarHandleSingleton.class);} catch (ReflectiveOperationException e) {throw new Error(e);}}private VarHandleSingleton() {}public static VarHandleSingleton getInstance() {if (instance == null) {synchronized (VarHandleSingleton.class) {if (instance == null) {INSTANCE_HANDLE.setVolatile(new VarHandleSingleton());}}}return instance;}
}

五、Records(JDK14+)​​ 实现不可变单例

结合 Records 类型创建不可变单例(需配合工厂方法):

public record DatabaseConfig(String url, String user) {private static final DatabaseConfig INSTANCE = new DatabaseConfig("jdbc:mysql://localhost:3306/db", "admin");public static DatabaseConfig getInstance() {return INSTANCE;}
}

六、Sealed Classes(JDK17+)​​ 限制子类化

通过密封类(Sealed Classes)防止单例被继承破坏:

public sealed class Logger permits LoggerSingleton {// 密封类定义
}public final class LoggerSingleton extends Logger {private static final LoggerSingleton INSTANCE = new LoggerSingleton();private LoggerSingleton() {}public static LoggerSingleton getInstance() {return INSTANCE;}
}

关键对比与选型建议

实现方式适用场景优势限制条件
Lambda + Supplier需要简洁语法 + 延迟加载代码简练,减少样板代码JDK8+
接口静态方法简单饿汉式单例天然支持全局访问点需配合实现类
模块化高安全性要求场景防止反射攻击JDK9+
VarHandle高性能要求的双重校验锁比 volatile 更底层控制JDK9+
Records不可变配置类单例自动生成equals/hashCode/toStringJDK14+(预览特性)
Sealed Classes防止单例被子类化破坏编译期安全检查JDK17+

总结

虽然 JDK8 后单例模式的核心思想未变,但新特性提供了 ​更安全、更简洁的实现选择​:

  1. 优先选择 Records/枚举​:对不可变配置类,Records 提供天然线程安全和简洁性。
  2. 高并发场景用 VarHandle​:替代传统双重校验锁,减少内存屏障开销。
  3. 模块化增强防御​:结合模块系统限制反射访问,提升安全性。
  4. 避免过度设计​:简单场景仍推荐枚举或静态内部类实现。
http://www.xdnf.cn/news/250777.html

相关文章:

  • C++之IO流
  • 如何让模型聪明地选择特征:一种“蒸馏及选择”的方法
  • Seata客户端代理增强核心源码解析
  • Laravel 12 实现 OAuth2 登录
  • 鼎讯信通 智能通信干扰设备:多频段多模态信号压制解决方案
  • 【C++11】智能指针
  • 【学习笔记】机器学习(Machine Learning) | 第五章(2)| 分类与逻辑回归
  • 第 12 届蓝桥杯 C++ 青少组中 / 高级组省赛 2021 年真题
  • Python3 基本数据类型
  • Python 常用内置函数详解(八):对象属性操作getattr()、setattr()、delattr()、hasattr()、vars()函数详解
  • 【经管数据】上市公司企业资本要素和劳动要素投入数据(2000-2022年)
  • Memory Bank 不够用?Cline 全新 CRCT:省 token,依赖关系自行追踪
  • 如何解决 H5 远程收款的问题呢?
  • 目标文件的段结构及核心组件详解
  • 多线程系列二:Thread类
  • Window通过虚拟机17安装Ubuntu20.04并安装相关的插件(胎教级教程)
  • 回归树:从原理到Python实战
  • 【C语言】文本操作函数fseek、ftell、rewind
  • 详细介绍Python-pandas-DataFrame全部 功能 函数
  • 存储器层次结构:理解计算机记忆的金字塔
  • 23页PDF | 数据治理实施方案 :规划、执行、评价、改进四步走的管控模式
  • Seata服务端开启事务核心源码解析
  • 位运算题目:寻找重复数
  • 最长公共前缀(14)
  • 基于Koa实现的服务端渲染 ✅
  • 8.进程概念(四)
  • 为什么大模型偏爱Markdown
  • 操作系统(1)多线程
  • 【Machine Learning Q and AI 读书笔记】- 03 小样本学习
  • 数字智慧方案6178丨智慧医院医疗信息化建设之以评促建(61页PPT)(文末有下载方式)