Python--设计模式之单例模式

python设计模式之单例模式#

单例模式#

确保一个类只有一个实例(也就是类的对象),并且提供一个全局的访问点(外部通过这个访问点来访问该类的唯一实例)。通俗的说就是,无论类实例化多少次,都只有一个相同的对象产生,并且可以通过一个具柄去访问这个这个唯一实例

类方法实现#

class SingleType:
    _instance = None

    @classmethod
    def instance(cls):
        if not cls._instance:
            cls._instance = SingleType()
        return cls._instance

for i in range(100):
    print(SingleType.instance())

结果:#

返回的都是同一个对象,实现了我们说的,无论调用多少次,都只返回同一个实例,但是这在多线程的环境中,可能会存在返回多个实例,我们实验一下。

可以看到在多线程的环境中,我们产生了两个2个对象,这就违背了我们的单例原则了,那怎么解决它呢,答案是加锁。

import threading
import time


class SingleType:
    _instance = None
    _lock = threading.Lock()

    def __init__(self):
        time.sleep(1)
        super().__init__()

    @classmethod
    def instance(cls):
        if not cls._instance:
            with SingleType._lock:
                if not cls._instance:
                    cls._instance = SingleType()
        return cls._instance

def task():
    obj = SingleType.instance()
    print(obj)

for i in range(10):
    t = threading.Thread(target=task).start()

装饰器模式实现#

def decorator(cls):
    def wrap(*args, **kwargs):
        if not cls._instance:
            cls._instance = cls()
        return cls._instance

    return wrap


@decorator
class SingleType:
    _instance = None

    def __init__(self):
        super().__init__()


for i in range(10):
    obj = SingleType()
    print(obj)

当然这里也会出现多线程创建多个实例的问题,可以参照上一个例子自行去实现多线程的版本

posted @   知无不言~  阅读(97)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示
主题色彩