Java中的单例模式是一种设计模式,它限制一个类只能创建一个实例,并提供全局访问点,以确保所有对象共享同一份资源。单例模式在许多场景下非常有用,比如管理资源(如数据库连接池)、实现缓存、配置信息类以及控制类等。 1. **饿汉式**: 饿汉式单例在类加载时就创建了实例,所以它是线程安全的。这种方式确保了在多线程环境下也能正确地初始化实例,但可能会造成资源的浪费,因为即使单例未被使用,也会被提前实例化。 ```java public class Singleton { private static final Singleton instance = new Singleton(); private Singleton() {} public static Singleton getInstance() { return instance; } } ``` 2. **懒汉式**: 懒汉式单例在首次调用 `getInstance` 方法时才创建实例,实现了延迟初始化。但原始的懒汉式是线程不安全的,因为在多线程环境下,可能会创建多个实例。 ```java public class Singleton { private static Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == null) { instance = new Singleton(); } return instance; } } ``` 3. **懒汉式(双重检查锁定)**: 双重检查锁定解决了懒汉式的线程安全问题。它在多线程环境中确保只有一个实例被创建,同时避免了不必要的同步开销。双重检查锁定的关键在于使用 `volatile` 关键字,保证了多线程环境下的可见性和有序性。 ```java public class Singleton { private volatile static Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == null) { synchronized (Singleton.class) { if (instance == null) { instance = new Singleton(); } } } return instance; } } ``` 4. **内部类单例**: 内部类单例使用类加载机制来保证单例的唯一性,因为类的加载是线程安全的。这种方式既实现了延迟初始化,又保证了线程安全。 ```java public class Singleton { private Singleton() {} private static class SingletonInstance { private static final Singleton INSTANCE = new Singleton(); } public static Singleton getInstance() { return SingletonInstance.INSTANCE; } } ``` 总结来说,Java中的单例模式有多种实现方式,每种方式都有其适用的场景和优缺点。饿汉式简单且线程安全,但可能导致资源浪费;懒汉式延迟初始化但线程不安全;双重检查锁定解决了线程安全问题但增加了代码复杂性;内部类单例结合了延迟初始化和线程安全性。选择哪种方式取决于具体的需求和性能考虑。
1