咱们知道函数是可以当作装饰器, 他应用的是 闭包函数特性, 实际类只要符合闭包的特性也可以当作装饰器。
讲解装饰器之前 必须明白一个 魔法函数 call, 代码如下 :
class Person():
def __init__(self,name):
self.name=name
p=Person("xiao hei")
print(p()) # 执行实例方法
结果就报错了, 大家要知道,这个 callable 的意思是不能被调用。 那该怎么能调用呢, 这个时候就用到魔法函数 call
print(p())
TypeError: 'Person' object is not callable
修改代码如下:
class Person():
def __init__(self,name):
self.name=name
def __call__(self): # 写个魔法函数
print(self.name)
test=Person("xiao hei")
test() # 这个实例方法 就自动执行 call 里面的内容, 所有的魔法函数都不需要调用方法名
打印结果就是 xiaohei
有了这个基础知识 后边的就和函数装饰器的知识一样 , 下边我写个简单的函数装饰器,然后我分析执行过程
class Person():
def __init__(self,func):
print(" init 方法进行初始化")
self.__func=func
def __call__(self):
print("开始执行 实例方法 fun")
self.__func()
@Person
def fun():
print("fun 方法执行")
fun()
打印结果如下:
init 方法进行初始化
开始执行 实例方法 fun
fun 方法执行
分析执行过程如下:
- @Person 相当于 fun=Person(fun) , 看不懂的 可以看我前面的装饰器的讲解 。
- Person(fun) 相当于实例化, 只是他传递的比较特殊是个方法的引用,
- 首先走的是 init 方法 初始化 , 打印了 init 方法进行初始化 ,然后 把方法fun 的引用交给了私有属性 __func
- 实例化完成以后 把Person(fun) 实例化对象把指针传递给 fun,
- fun 指向实例化对象 , 当执行 fun() 的时候,就相当于 前面我们介绍的第一部分的内容,实例化方法自动调用了 call
- 执行call 方法里的 self.__func() , 这个 func的指针指向大家了解吗,
- fun的指针 传递给>func 指针又给了>__func, 所以当我们执行self.__func 的时候 就相当于 执行 fun() 也就是被装饰的方法。