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

学习系列:5种常见的单例模式变体及其实现方式

单例模式是一种创建型设计模式,它保证一个类只有一个实例,并提供了一个全局访问点。在实际应用中,我们可能会遇到一些特殊情况,需要对单例模式进行一些变体,以满足不同的需求。下面介绍几种常见的单例模式变体。

1. 懒汉式单例模式

懒汉式单例模式是指在第一次调用时才创建实例。这种方式可以避免在程序启动时就创建实例,从而提高程序的启动速度。但是,由于在多线程环境下可能会出现竞争条件,因此需要进行同步处理,以保证线程安全性。

下面是一个简单的懒汉式单例模式的实现:

class Singleton:__instance = None@staticmethoddef get_instance():if Singleton.__instance is None:Singleton()return Singleton.__instancedef __init__(self):if Singleton.__instance is not None:raise Exception("This class is a singleton!")else:Singleton.__instance = self

在这个实现中,我们使用了一个静态变量 __instance 来保存实例。在 get_instance 方法中,如果实例不存在,则创建一个新的实例并返回;否则直接返回已有的实例。在 __init__ 方法中,我们检查 __instance 是否已经存在,如果存在则抛出异常,否则将当前实例赋值给 __instance

2. 饿汉式单例模式

饿汉式单例模式是指在类加载时就创建实例。这种方式可以避免在多线程环境下出现竞争条件,从而保证线程安全性。但是,由于在程序启动时就创建实例,可能会导致程序启动速度变慢。

下面是一个简单的饿汉式单例模式的实现:

class Singleton:__instance = Singleton()@staticmethoddef get_instance():return Singleton.__instance

在这个实现中,我们使用了一个静态变量 __instance 来保存实例。在类加载时,就创建了一个新的实例,并将其赋值给 __instance。在 get_instance 方法中,我们直接返回 __instance

3. 双重检查锁单例模式

双重检查锁单例模式是在懒汉式单例模式的基础上增加了同步锁,以提高线程安全性。在多线程环境下,可能会出现多个线程同时调用 get_instance 方法的情况,如果没有同步锁,就会导致创建多个实例的问题。使用同步锁可以避免这个问题,但是会影响程序的性能。

下面是一个简单的双重检查锁单例模式的实现:

import threadingclass Singleton:__instance = None__lock = threading.Lock()@staticmethoddef get_instance():if Singleton.__instance is None:with Singleton.__lock:if Singleton.__instance is None:Singleton()return Singleton.__instancedef __init__(self):if Singleton.__instance is not None:raise Exception("This class is a singleton!")else:Singleton.__instance = self

在这个实现中,我们使用了一个静态变量 __instance 来保存实例,以及一个同步锁 __lock。在 get_instance 方法中,我们首先检查 __instance 是否已经存在,如果不存在,则获取同步锁,并再次检查 __instance 是否已经存在。如果不存在,则创建一个新的实例,并将其赋值给 __instance。在 __init__ 方法中,我们检查 __instance 是否已经存在,如果存在则抛出异常,否则将当前实例赋值给 __instance

4. 静态内部类单例模式

静态内部类单例模式是利用静态内部类的特性,在类加载时创建实例,保证线程安全性。这种方式可以避免在程序启动时就创建实例,从而提高程序的启动速度。

下面是一个简单的静态内部类单例模式的实现:

class Singleton:class __Singleton:def __init__(self):self.value = Nonedef __str__(self):return "{0!r} {1}".format(self, self.value)__instance = Nonedef __new__(cls):if not Singleton.__instance:Singleton.__instance = Singleton.__Singleton()return Singleton.__instancedef __getattr__(self, name):return getattr(self.__instance, name)def __setattr__(self, name):return setattr(self.__instance, name)

在这个实现中,我们使用了一个静态内部类 __Singleton 来保存实例。在 __new__ 方法中,我们首先检查 __instance 是否已经存在,如果不存在,则创建一个新的实例,并将其赋值给 __instance。在 __getattr____setattr__ 方法中,我们将属性的访问委托给 __instance

5. 枚举单例模式

枚举单例模式是利用枚举类型的特性,保证只有一个实例,并且可以防止反射和序列化攻击。这种方式可以避免在程序启动时就创建实例,从而提高程序的启动速度。

下面是一个简单的枚举单例模式的实现:

from enum import Enumclass Singleton(Enum):INSTANCE = 1

在这个实现中,我们定义了一个枚举类型 Singleton,其中只有一个枚举值 INSTANCE。由于枚举类型的特性,保证只有一个实例,并且可以防止反射和序列化攻击。在使用时,我们可以直接使用枚举值 Singleton.INSTANCE 来访问单例实例。

总之,单例模式是一种非常有用的设计模式,可以帮助我们在程序中创建唯一的实例,并提供一个全局访问点。在实际应用中,我们可能会遇到一些特殊情况,需要对单例模式进行一些变体,以满足不同的需求。

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

相关文章:

  • 三菱FX5U系列PLC之间进行简易PLC间链接功能的具体方法
  • 基于DBACAN的道路轨迹点聚类
  • 【项目】接入飞书平台
  • c++11 标准模板(STL)(std::ios_base)(三)
  • 在线协同办公小程序开发搭建开发环境
  • 【编译、链接、装载六】汇编——目标文件
  • 王道计算机考研408计算机组成原理汇总(下)
  • 偏向锁、轻量级锁、重量级锁、自旋锁、自适应自旋锁
  • Delta 一个新的 git diff 对比显示工具
  • C# 二进制序列化和反序列化示例
  • 【CSS】文字扫光 | 渐变光
  • Overhaul Distillation(ICCV 2019)原理与代码解析
  • <Linux开发>驱动开发 -之-内核定时器与中断
  • 希尔贝壳邀您参加2023深圳国际人工智能展览会
  • 设计优质微信小程序的实用指南!
  • 大数据期末总结
  • selenium面试题总结
  • ⑧电子产品拆解分析-1拖4USB拓展坞
  • 月度精华汇总 | 最新XR行业资讯、场景案例、活动都在这一篇里啦!
  • Redis实战案例1-短信登录
  • 华为OD机试真题 JavaScript 实现【找终点】【2023 B卷 100分】,附详细解题思路
  • 详解数据仓库数据湖及湖仓一体
  • 基于注解切换、Hikari实现的SpringBoot动态数据源(支持JNDI)
  • Java中的动态链接VS操作系统动态链接
  • 深入理解Linux虚拟内存管理(七)
  • GSR II 智能速度辅助系统的型式认证和系统作为独立技术单元的型式认证测试流程和技术要求
  • 工厂方法模式(五)
  • 力扣笔记(每日随机一题)——最佳买卖股票时机含冷冻期
  • yolov5 6.1 关于 tensorrt 加速的使用以及问题说明
  • SVR(支持向量机)用法介绍