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

这篇具有很好参考价值的文章主要介绍了学习系列:5种常见的单例模式变体及其实现方式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

1. 懒汉式单例模式

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

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

class Singleton:
    __instance = None

    @staticmethod
    def get_instance():
        if Singleton.__instance is None:
            Singleton()
        return Singleton.__instance

    def __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()

    @staticmethod
    def get_instance():
        return Singleton.__instance

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

3. 双重检查锁单例模式

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

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

import threading

class Singleton:
    __instance = None
    __lock = threading.Lock()

    @staticmethod
    def get_instance():
        if Singleton.__instance is None:
            with Singleton.__lock:
                if Singleton.__instance is None:
                    Singleton()
        return Singleton.__instance

    def __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 = None

        def __str__(self):
            return "{0!r} {1}".format(self, self.value)

    __instance = None

    def __new__(cls):
        if not Singleton.__instance:
            Singleton.__instance = Singleton.__Singleton()
        return Singleton.__instance

    def __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 Enum

class Singleton(Enum):
    INSTANCE = 1

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

总之,单例模式是一种非常有用的设计模式,可以帮助我们在程序中创建唯一的实例,并提供一个全局访问点。在实际应用中,我们可能会遇到一些特殊情况,需要对单例模式进行一些变体,以满足不同的需求。文章来源地址https://www.toymoban.com/news/detail-487723.html

到了这里,关于学习系列:5种常见的单例模式变体及其实现方式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 委托的单例模式

     在项目中我们经常会使用到委托,委托是多播的,如果控制不好反复注册就会多次触发,可以使用委托的单例模式去注册,这样可以避免多次触发问题。 下面是几种委托实例代码: 带参数委托管理: 调用方法: ActionManager参数.Removal(\\\" 注册Key \\\"); ActionManager 参数 .Register(\\\" 注册

    2024年02月08日
    浏览(54)
  • 面向对象中的单例模式

    设计模式就是前人根据实际的问题提出的问题解决方案,我们把这种就称之为设计模式。 单例模式是一种常见的设计模式! 所谓的设计模式,不是一种新的语法,而是人们在实际的应用中,面对某种特定的情形而设计出来的某种常见的有效的解决方案,所以,设计模式只是

    2024年02月05日
    浏览(47)
  • Java设计模式中的单例模式

    Java设计模式中的单例模式 单例模式是一种创建型设计模式,其目的是确保一个类只有一个实例,并提供一个全局访问点。 单例模式的两种不同方式 饿汉式单例模式: 懒汉式单例模式: 区别: 饿汉式单例模式(Eager Initialization): 在类加载时就创建实例,因此不存在线程安

    2024年01月24日
    浏览(52)
  • 【多线程】线程安全的单例模式

    单例模式能保证某个类在程序中只存在 唯一 一份实例, 而不会创建出多个实例,从而节约了资源并实现数据共享。 比如 JDBC 中的 DataSource 实例就只需要一个. 单例模式具体的实现方式, 分成 “饿汉” 和 “懒汉” 两种. 类加载的同时, 创建实例. 注意: 使用 static 修饰 instanc

    2024年02月09日
    浏览(45)
  • C++ 中的单例模式singleton

    在面向对象编程中,设计模式是解决常见问题的最佳实践。单例模式是其中之一,它确保一个类只有一个实例,并提供一个全局访问点来获取该实例。在本文中,我们将详细介绍 C++ 中的单例模式。 单例模式是一种设计模式,它限制一个类只能创建一个对象。这个模式通常用

    2024年02月21日
    浏览(44)
  • python实现单例模式及其应用

    单例模式是一种常见的设计模式,它保证一个类只能被实例化一次,并提供了一个全局访问点来获取这个唯一的实例。 在 Python 中,可以通过使用装饰器、元类或模块等方式实现单例模式。下面分别介绍这三种方法: 1.使用装饰器实现单例模式 解析: 上述代码中,我们定义

    2024年02月07日
    浏览(42)
  • [Unity] 单例设计模式, 可供继承的单例组件模板类

    一个可供继承的单例组件模板类: 因为 Unity 是单线程的, 所以在这里没有必要使用双检索 例如你要创建一个全局的单例管理类, 可以这样使用: 尽量避免让 SingletonComponent 帮你创建组件, 因为它只是单纯的将组件创建, 并挂载到空对象上, 而不会进行任何其他行为. 如果你的组件

    2024年02月08日
    浏览(42)
  • 【谈一谈】: 我们工作中的单例模式有哪些写法?

    我们要实现一个单例,首先最重要的是什么? 当然是把构造函数私有化,变成 private 类型,(为啥? 单例单例,如果谁都能通过构造函数创建对象,还叫单例吗?是不~) 嗯~我们构造函数私有化后,我们应该 操作啥 呢? 接着我们需要提供 一个方法 ,这个方法要保证初始化 有且仅 初始化 一

    2024年02月21日
    浏览(48)
  • 7种创建方式,带你理解Java的单例模式

    本文分享自华为云社区《《Java极简设计模式》第01章:单例模式(Singleton)》,作者:冰 河。 看几个单例对象的示例代码,其中有些代码是线程安全的,有些则不是线程安全的,需要大家细细品味,这些代码也是在高并发环境下测试验证过的。 代码一:SingletonExample1 这个类

    2024年02月12日
    浏览(43)
  • 【JAVA】Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式

    🍎 个人博客: 个人主页 🏆 个人专栏: JAVA ⛳️   功不唐捐,玉汝于成 目录 前言 正文 懒汉式(Lazy Initialization): 双重检查锁定(Double-Checked Locking): 结语 我的其他博客 在软件设计中,单例设计模式是一种重要的设计思想,它确保了一个类只有一个实例,并提供了一

    2024年01月15日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包