Java中的单例模式实现方式比较

在Java中,单例模式是一种常用的设计模式,它确保一个类只有一个实例,并提供一个全局访问点。以下是几种常见的单例模式实现方式:

  1. 饿汉式单例模式

    • 在类加载时就完成了初始化,所以类加载比较慢,但获取对象的速度快。
    • 在类加载时就完成了初始化,如果线程安全环境下,可能会引发线程安全问题。
复制代码

java复制代码

|---|---------------------------------------------------------|
| | public class Singleton { |
| | // 在类加载时就完成了初始化,所以类加载比较慢 |
| | private static Singleton instance = new Singleton(); |
| | |
| | private Singleton() {} |
| | |
| | public static Singleton getInstance() { |
| | return instance; |
| | } |
| | } |

  1. 懒汉式单例模式

    • 类加载时不初始化,当调用 getInstance() 方法时才初始化。如果线程安全环境下,可能会引发线程安全问题。
复制代码

java复制代码

|---|---------------------------------------------------------|
| | public class Singleton { |
| | private static Singleton instance; |
| | |
| | private Singleton() {} |
| | |
| | public static synchronized Singleton getInstance() { |
| | if (instance == null) { |
| | instance = new Singleton(); |
| | } |
| | return instance; |
| | } |
| | } |

  1. 双重检查锁定(Double-Checked Locking)

    • 第一次检查是为了避免不必要的同步,第二次检查是为了防止多线程情况下创建多个实例。在Java 5及以上版本中,此方法可以安全地实现单例模式。
复制代码

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; |
| | } |
| | } |

  1. 静态内部类(静态嵌套类)

这是线程安全的懒汉式单例模式。由于JVM对类的加载是线程安全的,因此在类加载时不会发生线程安全问题。静态内部类在类加载时只会加载一次,所以只有在第一次调用 getInstance() 时才会创建实例。由于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; |
| | } |
| | } |

相关推荐
大模型真好玩13 分钟前
LangChain DeepAgents 速通指南(三)—— 让Agent告别混乱:Tool Selector与Todo List中间件解析
人工智能·langchain·trae
孟祥_成都1 小时前
【全网最通俗!新手到AI全栈开发必读】 AI 是如何进化到大模型的
前端·人工智能·全栈
Seven971 小时前
剑指offer-79、最⻓不含重复字符的⼦字符串
java
牛奶1 小时前
AI辅助开发的基础概念
前端·人工智能·ai编程
东坡肘子1 小时前
OpenClaw 不错,但我好像没有那么需要 -- 肘子的 Swift 周报 #125
人工智能·swiftui·swift
风象南9 小时前
普通人用AI加持赚到的第一个100块
人工智能·后端
牛奶9 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶9 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
皮皮林55110 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河10 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化