Java 饿汉式 单例模式
饿汉式(Eager Initialization)是 Java 单例模式中最简单、最基础的一种实现方式。它的核心思想非常形象:就像一个“饿汉”一样,迫不及待地在类加载时就提前把唯一的实例对象创建好,不管后续有没有用到,都先把“粮食”囤好。
以下是饿汉式单例模式的代码实现、核心原理以及优缺点分析:
📝 代码实现
publicclassHungrySingleton{// 1. 在类加载时,直接创建唯一的静态实例(饿汉式核心)privatestaticfinalHungrySingletonINSTANCE=newHungrySingleton();// 2. 私有化构造方法,禁止外部通过 new 关键字创建对象privateHungrySingleton(){}// 3. 提供全局公共的静态方法,供外部获取唯一的实例publicstaticHungrySingletongetInstance(){returnINSTANCE;}}💡 核心原理
饿汉式单例模式之所以能实现线程安全,主要依赖于JVM 的类加载机制。
在 Java 中,类的加载过程是线程安全的(由 JVM 保证一个类只会被加载一次)。饿汉式将实例的创建放在了静态变量初始化阶段,这意味着当类被加载时,实例就已经被创建好了。因此,它天然地避免了多线程并发创建多个实例的问题,不需要额外加锁。
✅ 优点
- 实现简单:代码非常简洁明了,易于理解和维护。
- 绝对线程安全:利用 JVM 类加载机制保证实例的唯一性,没有任何并发风险。
- 获取效率高:因为实例在类加载时就已经创建完毕,后续调用
getInstance()方法时直接返回即可,没有同步锁的开销,性能极高。
❌ 缺点
- 可能造成内存浪费:由于实例在类加载时就被创建,如果这个单例类在整个程序运行期间从未被使用过,那么这个提前创建好的实例就会一直占用内存,造成资源闲置。
- 延长启动时间:如果单例对象的初始化过程非常耗时(例如需要加载大量配置文件或建立复杂的数据库连接),会导致应用程序的启动速度变慢。
🎯 适用场景
饿汉式非常适合实例创建开销较小、且程序运行期间一定会被使用的场景,例如:
- 简单的全局配置管理器
- 轻量级的日志工具类
- 一定会用到的常量池或缓存管理器
如果你需要实现“用到时才创建”(即延迟加载/懒加载)的单例模式,可以考虑使用双重检查锁(DCL)或静态内部类的方式。
要不要看看饿汉式和懒加载(双重检查锁)在代码和性能上的具体对比?