标签:end 装饰器 模式 ret __init__ elf 特性 nonlocal 添加
我们知道,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
关于单例模式,有很多更方便的方法,这里主要用来熟悉下装饰器
标签:end 装饰器 模式 ret __init__ elf 特性 nonlocal 添加
原文地址:https://www.cnblogs.com/zxmbky/p/10218474.html