当前位置: 首页 > news >正文

92、23种设计模式-单例模式

单例模式(Singleton Pattern)是一种创建型设计模式,其核心目标是确保一个类在任何情况下都只有一个实例对象,并提供全局访问点以共享该实例。以下是单例模式的详细解析:

一、核心特点

  • 唯一实例:类自身负责创建并维护唯一实例,禁止外部通过构造函数直接实例化。
  • 全局访问:通过静态方法(如getInstance())提供对唯一实例的访问。
  • 延迟初始化(可选):实例可在首次使用时创建(懒汉式),或在类加载时创建(饿汉式)。

二、实现方式对比

单例模式有多种实现方式,各有优缺点,需根据场景选择:

实现方式代码示例优点
饿汉式(静态常量)public class Singleton { private static final Singleton INSTANCE = new Singleton(); private Singleton() {} public static Singleton getInstance() { return INSTANCE; } }线程安全(类加载时初始化)、实现简单。
懒汉式(线程不安全)public class Singleton { private static Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == null) { instance = new Singleton(); } return instance; } }延迟加载,节省内存。
懒汉式(同步方法)public class Singleton { private static Singleton instance; private Singleton() {} public static synchronized Singleton getInstance() { if (instance == null) { instance = new Singleton(); } return instance; } }线程安全。
双重检查锁定(DCL)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; } }线程安全、延迟加载、高效(仅首次同步)。
静态内部类public class Singleton { private Singleton() {} private static class SingletonHolder { private static final Singleton INSTANCE = new Singleton(); } public static Singleton getInstance() { return SingletonHolder.INSTANCE; } }线程安全(类加载机制保证)、延迟加载、无锁高效。
枚举实现public enum Singleton { INSTANCE; public void doSomething() {} }线程安全、防止反射攻击、自动支持序列化、实现简单。

三、推荐实现方式

1.枚举实现

  • 最佳选择:Java中枚举天然支持单例,可防止反射攻击和序列化问题,代码简洁。
  • 适用场景:无需延迟初始化,且希望代码健壮性高的场景。

2.静态内部类

  • 平衡之选:结合了线程安全、延迟加载和高效性,是懒汉式的优化实现。
  • 适用场景:需要延迟初始化且追求性能的场景。

3.双重检查锁定(DCL)

  • 高性能需求:在需要延迟加载且对性能敏感的场景下使用,但需注意volatile关键字的使用。

四、应用场景

  • 资源管理:如数据库连接池、线程池、文件系统等,需避免重复创建和销毁资源。
  • 配置管理:全局配置对象需唯一,确保配置一致性。
  • 日志记录:单例日志器可集中管理日志输出,避免多实例混乱。
  • 硬件控制:如打印机管理器、传感器控制器等,需单一控制逻辑。

五、注意事项

  • 线程安全:多线程环境下需确保单例的唯一性(推荐使用枚举、静态内部类或DCL)。
  • 反射攻击:通过反射可破坏单例(枚举实现可避免此问题)。
  • 序列化问题:单例类实现Serializable接口时,需重写readResolve()方法防止反序列化创建新实例。
  • 分布式系统:单例模式仅保证单个JVM内的唯一性,分布式环境下需结合其他机制(如分布式锁)。

总结

单例模式通过控制实例的创建和访问,有效降低了系统开销,确保了资源的高效利用。在实际开发中,应根据具体需求(如线程安全、延迟加载、性能等)选择合适的实现方式。枚举实现因其简洁性和健壮性,通常是Java中的首选方案;若需延迟加载,静态内部类是更灵活的选择。

在这里插入图片描述

http://www.dtcms.com/a/331047.html

相关文章:

  • 项目日志框架与jar中日志框架冲突 解决
  • 《多级缓存架构设计与实现全解析》
  • 自动化测试|持续集成Git使用详解
  • label studio 服务器端打开+xshell端口转发设置
  • 01数据结构-最短路径Dijkstra
  • 【数据结构入门】
  • 移动机器人底盘在高校科研中的AI智能教育应用
  • (第十五期)HTML文本格式化标签详解:让文字更有表现力
  • Flutter GetX 全面指南:状态管理、路由与依赖注入的最佳实践
  • SpringMVC请求与响应
  • 三坐标测量仪:从机械精密到智能协同的技术
  • flutter 开发 鸿蒙 App
  • gitee_配置自动部署vue项目
  • Uniapp 获取系统信息:uni.getSystemInfo 与 uni.getSystemInfoSync
  • vs2022 opencv环境配置(使用相对地址-将依赖都放入项目中)
  • spring boot配置es
  • 开发避坑指南(26):Vue3 input输入框前置后 置元素解决方案
  • 新增和编辑共用弹窗模板
  • .Net Core控制台程序连接HGDB并部署到Linux
  • 【C#】跨平台创建你的WinForms窗体应用(WindowsUbuntu)
  • 上网行为安全概述和组网方案
  • 深入解析 HTTP 协议演进:从 1.0 到 3.0
  • 【web站点安全开发】任务4:JavaScript与HTML/CSS的完美协作指南
  • 嵌入式Linux学习-编译内核源码
  • vscode的ws环境,esp32s3连接wifi
  • 深入解析Python身份切换:安全权限管理实践指南
  • MyBatis缓存模块深度解析
  • dolphinscheduler中任务输出变量的问题出现ArrayIndexOutOfBoundsException
  • MCP和Agent之间的区别和联系
  • vercel部署上线