Python的四种单例模式实现方式

 更新时间:2024年04月03日 09:46:08   作者:松柏  
单例模式是一种设计模式,用于确保一个类只有一个实例,并提供全局访问点以获取该实例,这篇文章主要介绍了Python的四种单例模式实现方式,需要的朋友可以参考下

Python客栈送红包、纸质书

★ 单例模式基本介绍

单例模式是一种设计模式,用于确保一个类只有一个实例,并提供全局访问点以获取该实例。它是一种创建型模式,通常用于需要严格控制某个类的实例数量的情况。单例模式确保一个类在整个应用程序生命周期中只有一个实例,因此可以节省系统资源,同时提供了一个集中的访问点,以便在需要时获取该实例。

★ 实现单例的几种方式:

  • 模块导入
  • 添加装饰器(类装饰器和函数装饰器)
  • 重写new方法
  • 元类继承

★ 方式一: 模块导入

文件结构

1
2
3
4
5
6
单例
├───file1.py
├───file2.py
├───readme
├───单例实现1_模块导入.py
└───模块导入实现单例测试.py

单例实现1_模块导入.py

1
2
3
4
5
6
7
8
9
10
11
12
13
14
"""
模块导入实现单例模式步骤:
1. 在模块中定义类
2. 实例化类并返回
3. 在其他文件中导入实例对象使用, 每个文件导入的对象实际是同一个
"""
class Singleton:
    def __init__(self, name):
        self.name = name
    def do_something(self):
        pass
singleton = Singleton('模块单例')
# 在其他py文件中
# from my_singleton import singleton

file1.py

1
2
from 单例实现1_模块导入 import singleton
print(singleton)

file2.py

1
2
from 单例实现1_模块导入 import singleton
print(singleton)

模块导入实现单例测试.py

1
2
3
import file1
import file2
print(file1.singleton is file2.singleton)

执行结果

<单例实现1_模块导入.Singleton object at 0x0000021B2B81F400>
<单例实现1_模块导入.Singleton object at 0x0000021B2B81F400>
True

★ 方式二: 装饰器

单例实现2_装饰器.py

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# -------------------函数装饰器---------------------------
def Singleton1(cls):
    instance = {}
    def _singleton_wrapper(*args, **kargs):
        if cls not in instance:
            instance[cls] = cls(*args, **kargs)
        return instance[cls]
    return _singleton_wrapper
# -------------------类装饰器---------------------------
class Singleton2:
    def __init__(self, cls):
        self.cls = cls
        self._instance = None
    def __call__(self, *args, **kwargs):
        if not self._instance:
            self._instance = self.cls(*args, **kwargs)
        return self._instance
# SingletonTest = Singleton1(SingletonTest) =_singleton_wrapper
# SingletonTest = Singleton2(SingletonTest) = Singleton2实例对象
@Singleton1
class SingletonTest(object):
    def __init__(self, name):
        print(">>> 初始化 <<<")
        self.name = name
s1 = SingletonTest('s1')
s2 = SingletonTest('s2')
print(s1, s2)
print(s1 is s2)

执行结果

>>> 初始化 <<<
<__main__.SingletonTest object at 0x000001E6A2FF73D0> <__main__.SingletonTest object at 0x000001E6A2FF73D0>
True

★ 方式三: 重写new方法

单例实现3_重写new方法.py

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class Singleton(object):
    def __new__(cls, *args, **kwargs):
        if not hasattr(Singleton, "_instance"):
            Singleton._init_flag = True
            Singleton._instance = super().__new__(cls)
        return Singleton._instance
    def __init__(self, name):
        if not hasattr(Singleton, "_init"):
            Singleton._init = True
            print(">>> 初始化 <<<")
            self.name = name
s1 = Singleton('s1')
s2 = Singleton('s2')
print(s1, s2)
print(s1 is s2)

执行结果

>>> 初始化 <<<
<__main__.Singleton object at 0x0000016663140760> <__main__.Singleton object at 0x0000016663140760>
True

★ 方式四: 元类继承

单例实现4_元类继承.py

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
class Singleton(type):
    def __call__(cls, *args, **kwargs):
        if not hasattr(Singleton, "_instance"):
            # cls 是 Singleton 创建的类
            Singleton._instance = cls.__new__(cls, *args, **kwargs)
            cls.__init__(Singleton._instance, *args, **kwargs)
        return Singleton._instance
class SingletonTest(metaclass=Singleton):
    pass
class A(SingletonTest):
    def __init__(self, name):
        print(">>> 初始化 <<<")
        self.name = name
s1 = A('s1')
s2 = A('s2')
print(s1, s2)
print(s1 is s2)

执行结果

>>> 初始化 <<<
<__main__.A object at 0x000001687C79D5E0> <__main__.A object at 0x000001687C79D5E0>
True

到此这篇关于Python的四种单例模式实现方式的文章就介绍到这了,更多相关Python单例模式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

原文链接:https://www.cnblogs.com/cs-songbai/p/18111348

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!

相关文章

  • django自定义非主键自增字段类型详解(auto increment field)

    django自定义非主键自增字段类型详解(auto increment field)

    这篇文章主要介绍了django自定义非主键自增字段类型详解(auto increment field),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • Python实现上下文管理器的方法

    Python实现上下文管理器的方法

    这篇文章主要介绍了Python实现上下文管理器的方法,帮助大家更好的理解和学习Python,感兴趣的朋友可以了解下
    2020-08-08
  • Python搭建代理IP池实现存储IP的方法

    Python搭建代理IP池实现存储IP的方法

    这篇文章主要介绍了Python搭建代理IP池实现存储IP的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Python实现Web服务器FastAPI的步骤详解

    Python实现Web服务器FastAPI的步骤详解

    FastAPI 是一个用于构建 API 的现代、快速(高性能)的 web 框架,使用 Python 3.6+ 并基于标准的 Python类型提示,这篇文章主要介绍了Python实现Web服务器FastAPI的过程,需要的朋友可以参考下
    2022-06-06
  • 使用numba对Python运算加速的方法

    使用numba对Python运算加速的方法

    今天小编就为大家分享一篇使用numba对Python运算加速的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-10-10
  • 如何利用Python随机从list中挑选一个元素

    如何利用Python随机从list中挑选一个元素

    这篇文章主要介绍了如何利用Python随机从list中挑选一个元素,文章通过研究从列表中选择随机元素的不同实现方法展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-05-05
  • Python实现加密的RAR文件解压的方法(密码已知)

    Python实现加密的RAR文件解压的方法(密码已知)

    这篇文章主要介绍了Python实现加密的RAR文件解压,本文分步骤给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • numpy.ndarray 交换多维数组(矩阵)的行/列方法

    numpy.ndarray 交换多维数组(矩阵)的行/列方法

    今天小编就为大家分享一篇numpy.ndarray 交换多维数组(矩阵)的行/列方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • python中open函数的基本用法示例

    python中open函数的基本用法示例

    这篇文章主要给大家介绍了关于python中open函数的基本用法,文中通过示例代码介绍的非常详细,对大家学习或者使用python具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • Python中optparser库用法实例详解

    Python中optparser库用法实例详解

    这篇文章主要介绍了Python中optparser库用法实例详解,介绍了optparser的引入,初始化等相关内容,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01

最新评论