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

男女性直接做的视频网站网页首页管理系统

男女性直接做的视频网站,网页首页管理系统,徐闻网站建设公司,京东网上商城电话单例模式:深入解析全局唯一对象的艺术 引言:为什么需要单例? 在软件设计中,某些对象只需要一个全局实例——配置文件管理器、线程池、数据库连接池、日志系统等。创建多个实例不仅浪费资源,还可能导致状态不一致。单例…

单例模式:深入解析全局唯一对象的艺术

引言:为什么需要单例?

在软件设计中,某些对象只需要一个全局实例——配置文件管理器、线程池、数据库连接池、日志系统等。创建多个实例不仅浪费资源,还可能导致状态不一致。单例模式(Singleton Pattern)正是为解决这类问题而生的创建型设计模式,它确保一个类仅有一个实例,并提供全局访问点。


一、单例模式的核心思想

三大核心要素

  1. 私有化构造函数
    防止外部通过new创建实例
  2. 静态私有成员变量
    持有类的唯一实例
  3. 静态公有访问方法
    提供全局访问入口(通常命名为getInstance()

UML 类图

Singleton
- static instance: Singleton
-Singleton()
+static getInstance()

二、单例模式的 5 种经典实现

1. 饿汉式(Eager Initialization)

public class EagerSingleton {// 类加载时立即初始化private static final EagerSingleton instance = new EagerSingleton();private EagerSingleton() {}public static EagerSingleton getInstance() {return instance;}
}

特点

  • ✅ 线程安全(由JVM类加载机制保证)
  • ❌ 可能造成资源浪费(未使用即加载)

2. 懒汉式(Lazy Initialization)

基础版(线程不安全)
public class LazySingleton {private static LazySingleton instance;private LazySingleton() {}public static LazySingleton getInstance() {if (instance == null) {instance = new LazySingleton(); // 多线程下可能创建多个实例}return instance;}
}
同步方法版(线程安全但低效)
public synchronized static LazySingleton getInstance() {if (instance == null) {instance = new LazySingleton();}return instance;
}

缺点:每次访问都加锁,性能差

双重检查锁(DCL - Double-Checked Locking)
public class DCLSingleton {private volatile static DCLSingleton instance; // volatile 禁止指令重排序private DCLSingleton() {}public static DCLSingleton getInstance() {if (instance == null) {                    // 第一次检查synchronized (DCLSingleton.class) {    // 加锁if (instance == null) {            // 第二次检查instance = new DCLSingleton(); // 初始化}}}return instance;}
}

关键点

  • volatile 防止JVM指令重排序导致的未初始化完成对象被引用
  • 两次判空避免重复加锁

3. 静态内部类(Holder Pattern)

public class HolderSingleton {private HolderSingleton() {}private static class SingletonHolder {private static final HolderSingleton INSTANCE = new HolderSingleton();}public static HolderSingleton getInstance() {return SingletonHolder.INSTANCE; // 触发类加载}
}

原理
利用JVM的类加载机制保证线程安全
静态内部类在首次调用getInstance()时才加载,实现延迟初始化

4. 枚举实现(Effective Java 推荐)

public enum EnumSingleton {INSTANCE; // 单例实例public void doSomething() {System.out.println("Singleton method");}
}

优势

  • ✅ 绝对防止反射攻击
  • ✅ 自动支持序列化
  • ✅ 代码最简洁
  • ✅ 线程安全

三、单例模式的典型应用场景

  1. 配置管理类
    全局共享的配置信息(如ConfigManager
  2. 日志系统
    统一收集日志的Logger对象
  3. 线程池/连接池
    池化技术需要统一管理资源
  4. 缓存系统
    全局缓存对象(如Redis客户端连接)
  5. 硬件接口访问
    打印机、显卡驱动等独占资源

四、单例模式的潜在缺陷

1. 多线程环境问题

  • 竞态条件(Race Condition)
  • 可见性问题(未使用volatile

2. 反射攻击解决方案

private Singleton() {if (instance != null) {throw new IllegalStateException("Singleton already initialized");}
}

3. 序列化破坏单例

需添加readResolve()方法:

protected Object readResolve() {return getInstance();
}

4. 单元测试困难

  • 单例状态全局共享导致测试相互影响
  • 解决方案:依赖注入或重置机制

五、单例模式在框架中的应用

Spring 框架中的单例

@Service // 默认单例作用域
public class UserServiceImpl implements UserService {// 业务代码
}

特点

  • Bean默认单例(通过IoC容器管理)
  • 非传统单例(可通过多个容器创建不同实例)

Java 标准库案例

Runtime runtime = Runtime.getRuntime(); // 饿汉式实现
Desktop desktop = Desktop.getDesktop(); 

六、单例模式 vs 静态类

特性单例模式静态类
实现方式对象实例静态方法
接口实现✅ 可实现接口❌ 不能
继承✅ 可继承父类❌ 不能
延迟初始化✅ 支持❌ 类加载即初始化
状态管理✅ 可维护状态❌ 无状态

七、单例模式的最佳实践

  1. 优先选择枚举实现
    《Effective Java》第一条款推荐
  2. 需要延迟加载时用静态内部类
    兼顾线程安全和性能
  3. 避免全局状态污染
    谨慎使用单例存储可变数据
  4. 考虑依赖注入替代
    在Spring等框架中优先使用IoC管理

八、经典面试题解析

Q1:DCL为什么要用volatile?

private volatile static Singleton instance;

答案
防止指令重排序。对象初始化分为三步:

  1. 分配内存空间
  2. 初始化对象
  3. 将引用指向内存地址
    若步骤2、3重排序,其他线程可能拿到未初始化的对象。

Q2:如何防止克隆破坏单例?

@Override
protected Object clone() throws CloneNotSupportedException {throw new CloneNotSupportedException("Singleton cannot be cloned");
}

总结:单例模式的哲学

单例模式通过控制实例化过程,在保证全局唯一性的同时提供了灵活性。其价值不仅在于技术实现,更体现了资源治理边界控制的设计思想。随着云原生和微服务架构兴起,单例的应用场景正在向“单例作用域”(如Kubernetes Pod内的单例)演进,但其核心设计理念永不褪色。

最后提醒: 不要为了用单例而用单例!当你的需求符合“系统中有且只需一个全局对象”时,再考虑它。

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

相关文章:

  • 数字孪生 3D 风电场:HT 海上风电智慧化解决方案
  • 示波器使用,查看3d线扫相机的问题
  • 【汽车篇】基于深度学习的2D+3D整车漆面外观缺陷检测
  • (14)ASP.NET Core2.2 中的日志记录
  • Three.js 开发实战教程(五):外部 3D 模型加载与优化实战
  • SpringBoot 整合机器学习框架 Weka 实战操作详解:从 0 到 1 构建可扩展的智能预测微服务
  • 【qml-10】Quick3D实现机器人渲染(mesh)记录
  • 解构IDP未来前景:去中心化金融的“阳谋”与以人为本的生态蓝图(解读)
  • 怎么做淘宝网站百度公司招聘官网最新招聘
  • 【国标36964解读】《软件工程软件开发成本度量规范》(GB/T36964-2018)解读
  • 在 Windows 11 上从零复现 3D Gaussian Splatting (3DGS)
  • 软件设计师软考备战:第五篇 软件工程与项目管理
  • 接口访问速度突然变慢,怎么排查
  • C++ IO 库全方位解析:从基础到实战
  • 从“手机拆修”看懂POD与非POD的区别
  • vc无法启动
  • SenseVoice微调
  • 【C++】: list介绍以及模拟实现
  • dlib 实战:人脸检测、关键点定位与疲劳检测的全流程实现
  • SpringBoot 整合机器学习框架 Weka 实战操作详解:MLOps 端到端流水线与知识图谱融合实践
  • 华为OD最新机试题A卷双机位-单词接龙-2025年
  • Python 爬虫(豆瓣top250)-享受爬取信息的快乐
  • Kafka选举机制深度解析:分布式系统中的民主与效率
  • 一文读懂费用分析:定义、分类与成本费用区别
  • 全国做网站找哪家好做宣传海报的网站
  • 【Linux】基础IO(3)
  • 【Redis学习】Redis中常见的全局命令、数据结构和内部编码
  • AI行业应用深度解析:从理论到实践
  • AI 伦理审查破局:从制度设计到实践落地的 2025 探索
  • RocketMQ面试问题与详细回答