使用python写一个线程安全的单例

本文探讨了Python中实现线程安全单例模式的方法。通过使用装饰器和线程锁,确保了在多线程环境下单例模式的正确性和安全性。文章提供了具体的代码示例,展示了如何创建和使用线程安全的单例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单例在各种编程语言开发中都很常见,前面我们使用Java OC swift 分别对单例进行了探讨,下面我们使用python写一个线程安全的单例。

import threading


def synchronized(func):
    func.__lock__ = threading.Lock()

    def lock_func(*args, **kwargs):
        with func.__lock__:
            return func(*args, **kwargs)

    return lock_func


class Singleton(object):
    instance = None

    @synchronized
    def __new__(cls, *args, **kwargs):
        """
        :type kwargs: object
        """
        if cls.instance is None:
            cls.instance = super().__new__(cls)
        return cls.instance


if __name__ == "__main__":
    a = Singleton(3)
    print("a单例! id为 %s" % id(a))
    b = Singleton(4)
    print("b单例! id为 %s" % id(b))
    str = "hello world !"
    c = Singleton(str)
    print("c单例! id为 %s" % id(c))
    
    print("ok!")

在python3中,调用父类的方法是用super()来调用。
我们这里通过锁来进行保护,保证多线程的情况下同一时刻只有一个线程访问,这就保证了单例模式的安全
将类传入单例修饰器中,如果该类还未生成实例(instances中不存在该类),那么就生成一个新的实例返回,并记录在instances中。如果已经instances中已经存在该类,那么直接返回实例cls.instance

id是内置方法,我们通过id来判断对象是否是单例。运行结果如下

python线程安全的单例

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值