python线程安全的单例模式_详解python实现线程安全的单例
模式
单例模式是⼀种常见的设计模式,该模式的主要⽬的是确保某⼀个类只有⼀个实例存在。当你希望在整个系统中,某个类只能出现⼀个实例时,单例对象就能派上⽤场。
⽐如,服务器的配置信息写在⼀个⽂件中f中,客户端通过⼀个 Config 的类来读取配置⽂件的内容。如果在程序运⾏期间,有很多地⽅都需要使⽤配置⽂件的内容,那么每个调⽤配置⽂件的地⽅都会创建 Config的实例,这就导致系统中存在多个Config 的实例对象,在配置⽂件内容很多的情况下,我们就浪费了⼤量的内存做了同样的事。事实上,对于Config类我们在程序运⾏期间时只需要⼀个实例对象即可,这时单例模式就是最好的选择。
python的模块就是天然的单例模式,这⾥我们使⽤修饰器来实现单例模式,以下是代码实现
def Singleton(cls):
instances = {}
def get_instance(*args, **kw):
if cls not in instances:
instances[cls] = cls(*args, **kw)
return instances[cls]
return get_instance
代码也很简单,将类传⼊单例修饰器中,如果该类还未⽣成实例(instances中不存在该类),那么就⽣成⼀个新的实例返回,并记录在instances中。如果已经instances中已经存在该类,那么直接返回实例instances[cls]。
那么这段代码是完美的吗?答案是否定的,这段代码不是线程安全的。要实现线程安全需要配合锁的使⽤,只有占有锁的线程才能继续访问单例实例,看来我们需要再写⼀个修饰器来实现线程安全了,以下是完整的代码实现和简单的多线程测试⽤例。
#!/usr/bin/python
# -*- coding: utf-8 -*-
import threading
def synchronized(func):
func.__lock__ = threading.Lock()
def synced_func(*args, **kws):
with func.__lock__:
return func(*args, **kws)
return synced_func
def Singleton(cls):
instances = {}
@synchronized
def get_instance(*args, **kw):
if cls not in instances:
instances[cls] = cls(*args, **kw)
return instances[cls]
return get_instance
def worker():
single_test = test()
print "id----> %s" % id(single_test)
@Singleton
class test():
a = 1
if __name__ == "__main__":
task_list = []
for one in range(30):
t = threading.Thread(target=worker)
task_list.append(t)
for one in task_list:
python单例模式one.start()
for one in task_list:
one.join()
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持脚本之家。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论