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

详细讲解什么是单例模式

        当谈到单例模式时,我们指的是一种设计模式,它确保一个类只有一个实例,并提供一个全局访问点来访问该实例。这种模式在软件开发中很常见,特别是需要控制资源访问、配置管理、日志记录器等情况下。

让我们用一个简单的例子来解释单例模式:

        假设有一个名为 Logger 的日志记录器类,我们希望确保系统中只有一个日志记录器实例,以便在整个应用程序中记录日志。

public class Logger {// 声明一个私有静态变量来保存单例实例private static Logger instance;// 私有构造函数,防止外部直接实例化该类private Logger() {// 这里可以进行初始化操作}// 公共静态方法来获取单例实例public static Logger getInstance() {// 如果实例不存在,则创建一个新实例if (instance == null) {instance = new Logger();}// 返回单例实例return instance;}public void log(String message) {// 记录日志的具体逻辑System.out.println(message);}
}

现在,让我们来理解上述代码:

  1. 私有静态变量 instance 这是用来保存单例实例的变量。它被声明为私有,因此其他类无法直接访问它。

  2. 私有构造函数: 构造函数被声明为私有,这意味着其他类无法通过 new 关键字直接实例化 Logger 类。

  3. getInstance() 方法: 这是获取 Logger 实例的静态方法。它首先检查实例是否已经存在,如果不存在,则创建一个新的实例并将其返回。如果实例已经存在,则直接返回现有的实例。

使用单例模式的示例代码如下:

public class Main {public static void main(String[] args) {// 获取 Logger 实例Logger logger1 = Logger.getInstance();Logger logger2 = Logger.getInstance();// 验证 logger1 和 logger2 是否是同一个实例System.out.println(logger1 == logger2); // 这里应该打印 true// 使用日志记录器记录信息logger1.log("This is a log message.");logger2.log("Another log message.");}
}

        在这个例子中,Logger 类只有一个实例,并且通过 getInstance() 方法进行访问。当我们尝试使用两个不同的变量 logger1logger2 获取实例时,实际上它们都引用了相同的实例,因此打印结果为 true。这确保了系统中只有一个 Logger 实例,并且任何地方使用日志记录器都在操作同一个实例。

        实际上,上面的例子展示的是最基本的单例模式,它是一种简单的懒汉式实现。懒汉式指的是在首次被调用时才创建实例。在这个例子中,当调用 getInstance() 方法时,会检查实例是否已经存在,如果不存在则创建一个新实例,否则返回现有实例。

        另一种常见的单例模式是饿汉式单例模式。饿汉式指的是在类加载时就创建实例,而不是在首次被调用时才创建。让我们来看一下饿汉式单例模式:

public class EagerSingleton {// 在类加载时就创建实例并进行初始化private static final EagerSingleton instance = new EagerSingleton();// 私有构造函数,防止外部直接实例化该类private EagerSingleton() {// 这里可以进行初始化操作}// 公共静态方法来获取单例实例public static EagerSingleton getInstance() {return instance;}public void someBusinessLogic() {// 进行一些业务逻辑操作}
}

在这个例子中:

  1. EagerSingleton 类有一个私有的、静态的、最终的实例变量 instance,它在类加载时就被创建和初始化。

  2. 构造函数被声明为私有,确保外部无法直接实例化该类。

  3. getInstance() 方法简单地返回预先创建的实例。

        饿汉式单例模式的优点是实现简单,并且在多线程环境下能够保持线程安全,因为实例在类加载时就已经创建。但缺点是如果该实例在整个程序运行期间未被使用,会造成资源浪费,因为它在类加载时就被创建了。

        懒汉式和饿汉式单例模式各有其适用的场景。懒汉式可以延迟实例化,只有在需要时才创建,而饿汉式则在程序启动时就创建,适用于实例始终需要被使用的情况。

        单例模式可以帮助我们确保全局只有一个特定类的实例存在,这对于需要共享相同资源或状态的情况非常有用。但需要注意,如果不恰当地使用单例模式,可能会导致全局状态的滥用和应用程序结构的混乱。

http://www.lryc.cn/news/237487.html

相关文章:

  • 在springBoot中同时使用mysql和MongoDB
  • 2023.11.19 hadoop之MapReduce
  • 力扣第841题 钥匙和房间 C++ DFS BFS 附Java代码
  • React 中 react-i18next 切换语言( 项目国际化 )
  • antd design 5 版本 文件上传
  • 【如何学习Python自动化测试】—— 浏览器操作
  • Python编程技巧 – 使用字典
  • el-tree 与table表格联动
  • Leetcode刷题详解——删除并获得点数
  • HTTP四种请求方式,状态码,请求和响应报文
  • Python - Wave2lip 环境配置与 Wave2lip x GFP-GAN 实战 [超详细!]
  • 2311rust,1.31版本更新
  • 文心一言-情感关怀之旅
  • 下厨房网站月度最佳栏目菜谱数据获取及分析PLus
  • buildadmin+tp8表格操作(5)自定义组装搜索的查询
  • 企业级固态硬盘如何稳定运行?永铭固液混合铝电解电容来帮忙
  • 【MISRA C 2012】Rule 4.2 不应该使用三连符
  • spring boot加mybatis puls实现,在新增/修改时,对某些字段进行处理,使用的@TableField()
  • 如何构建风险矩阵?3大注意事项
  • SpringSecurity5|12.实现RememberMe 及 实现原理分析
  • 持续集成交付CICD:Jenkins Sharedlibrary 共享库
  • Linux--网络编程
  • 数据结构 并查集
  • 算法通关村第十六关黄金挑战——求滑动窗口中的最大值(滑动窗口与堆方法、双端队列法和直接比较法)
  • 常见树种(贵州省):009楠木、樟木、桂木种类
  • 全志H616开发版
  • 【Spring boot】RedisTemplate中String、Hash、List设置过期时间
  • Nosql之redis概述及基本操作
  • 使ros1和ros2的bag一直互通
  • 【正点原子 linux 驱动编程】