单例模式是一种常用的软件设计模式,其核心思想是确保一个类只有一个实例,并提供一个全局访问点。单例模式广泛应用于各种场景,如数据库连接、配置文件读取等。本文将深入探讨单例模式的实现方法,特别是如何构建线程安全的完美单例。
单例模式实现
单例模式有多种实现方式,以下列举几种常见的实现方法:
1. 懒汉式
懒汉式单例在类加载时不初始化,第一次使用时才创建实例。这种方式简单易实现,但存在线程安全问题。
public class LazySingleton {
private static LazySingleton instance;
private LazySingleton() {}
public static synchronized LazySingleton getInstance() {
if (instance == null) {
instance = new LazySingleton();
}
return instance;
}
}
2. 饿汉式
饿汉式单例在类加载时就初始化,保证了线程安全,但可能造成资源浪费。
public class EagerSingleton {
private static final EagerSingleton instance = new EagerSingleton();
private EagerSingleton() {}
public static EagerSingleton getInstance() {
return instance;
}
}
3. 双重校验锁
双重校验锁(Double-Checked Locking)是一种既保证了线程安全,又避免了资源浪费的实现方式。
public class DoubleCheckedLockingSingleton {
private static volatile DoubleCheckedLockingSingleton instance;
private DoubleCheckedLockingSingleton() {}
public static DoubleCheckedLockingSingleton getInstance() {
if (instance == null) {
synchronized (DoubleCheckedLockingSingleton.class) {
if (instance == null) {
instance = new DoubleCheckedLockingSingleton();
}
}
}
return instance;
}
}
4. 静态内部类
静态内部类单例利用了类加载机制保证线程安全,且避免了同步带来的性能损耗。
public class StaticInnerClassSingleton {
private static class SingletonHolder {
private static final StaticInnerClassSingleton INSTANCE = new StaticInnerClassSingleton();
}
private StaticInnerClassSingleton() {}
public static final StaticInnerClassSingleton getInstance() {
return SingletonHolder.INSTANCE;
}
}
5. 枚举
枚举是实现单例的最佳方式,不仅保证了线程安全,还防止了反序列化重新创建新的实例。
public enum EnumSingleton {
INSTANCE;
public void someMethod() {
// 业务逻辑
}
}
总结
本文介绍了单例模式的几种实现方式,包括懒汉式、饿汉式、双重校验锁、静态内部类和枚举。在实际应用中,应根据具体需求选择合适的实现方式。特别是对于高并发场景,应优先考虑双重校验锁和静态内部类这两种方式。
