装饰器实现单例模式

本文探讨如何利用Python装饰器来实现单例模式。装饰器本质上是对对象的包装,可以应用于函数或类。文中通过一个例子展示了装饰器在单例模式中的应用,并预告将补充带参数的装饰器及functools.wraps的相关内容。

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

用装饰器实现单例模式,应该算一个很不错的例子。


我们知道,python中装饰器无非是对对象的重新包装,这个对象可以是函数,也可以是一个类


@decorate
def test():
相当于 test = decorate(test)

def decorate(func):
	def wrap(*args,**kwargs):
		*****
		return 
	return wrap

不难发现,test其实就是wrap,我们可以在wrap中实现test的逻辑,并添加一些我们想要附加的特性,这样,相当于将test包装了一下,也就是‘装饰’了一下

由于类也可以被装饰,我们以单例模式的实现为例

能想到的办法一

def single01(cls):
	s=[]  //这里定义了一个私有列表,也可以声明一个变量,在wrap用关键字nonlocal去调用
	def wrap(*args,**kwargs):
		if not s:
			s.append(cls(*args,**kwargs))
		return s
	return wrap

@single01
class A(object):
	def __init__(self,name):
		self.name = name
//试一下
>>> a = A("tmac")
>>> b = A("kobe")
>>> 
>>> a is b
True


也可以写成将装饰器写成类的形式

class single03(object):
		def __init__(self,cls):
			self._cls = cls
			self._instances = None;
		def __call__(self,*args):
			if not self._instances:
				self._instances = self._cls(*args)
			return self._instances

//一样调用
@single03
class A(object):
	def __init__(self,name):
		self.name = name

关于单例模式,有很多更方便的方法,这里主要用来熟悉下装饰器

下篇补充下 带参数的装饰器 以及functools.wraps


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值