懒加载单例模式在Java中通过延迟实例化并保证线程安全,常见实现有:1. 双重检查锁定,使用volatile和synchronized确保高效且安全;2. 静态内部类,利用JVM类加载机制实现懒加载与线程安全;3. 枚举方式,代码简洁且天然防反射和序列化破坏;4. synchronized方法,线程安全但性能低。推荐使用双重检查锁定、静态内部类或枚举方式。

在Java中,懒加载单例模式的核心是:类的实例在第一次被使用时才创建,同时保证多线程环境下只创建一个实例。实现线程安全的懒加载单例有多种方式,下面介绍几种常见且有效的实现方法。
这是最常用的线程安全懒加载实现方式,通过synchronized关键字和volatile修饰符配合使用,确保性能和安全性。
代码示例:
public class Singleton {
private static volatile Singleton instance;
private Singleton() {}
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
利用类加载机制保证线程安全,同时实现懒加载。JVM保证类的初始化是线程安全的,且内部类在外部类加载时不立即加载。
立即学习“Java免费学习笔记(深入)”;
代码示例:
public class Singleton {
private Singleton() {}
private static class Holder {
private static final Singleton INSTANCE = new Singleton();
}
public static Singleton getInstance() {
return Holder.INSTANCE;
}
}
Effective Java作者Joshua Bloch推荐使用枚举实现单例,天然防止反射攻击和序列化破坏,代码简洁。
代码示例:
public enum Singleton {
INSTANCE;
public void doSomething() {
// 业务方法
}
}
早期实现方式,对整个getInstance方法加锁,线程安全但性能较差,每次调用都会同步。
不推荐用于高频调用场景。
public class Singleton {
private static Singleton instance;
private Singleton() {}
public static synchronized Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
以上就是Java里如何实现线程安全的懒加载单例_懒加载单例实现方法解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号