在python的类中,制作一个装饰器的函数,
class A:
def wrapper(func): ###装饰器
def wrapped(self,*arg,**kwargs)
...
return wrapped @ wrapper ###装饰mix
def mix():
...
当调用mix的时候,self.mix() ,会将self等参数传入 wrapper 中来吗?答案为否。
当wrapper作为装饰器的并且@wrapper这种方式作为装饰的时候,wrapper就跟普通的函数一样,仅仅接收被装饰的函数作为参数,并不会对装饰器传入额外的任何self,cls等参数,而类就相当于一个命名空间而已。
wrapper本身用@staticmethod,与@classmethod装饰,会得出错误。
'staticmethod' object is not callable 'classmethod' object is not callable
因为装饰器必须是能够被调用的对象,而wrapper被@staticmethod,与@classmethod装饰过后,就不是一个可被调用的对象了。
后面测试:父类被装饰器装饰过的某个函数例如A,在子类中可以继承该A函数并进行重写(无需加装饰器),采用super没有问题。