python高级进阶_6_类当作装饰器原理以及执行过程07

咱们知道函数是可以当作装饰器, 他应用的是 闭包函数特性, 实际类只要符合闭包的特性也可以当作装饰器。

讲解装饰器之前 必须明白一个 魔法函数 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 方法执行

分析执行过程如下:

  1. @Person 相当于 fun=Person(fun) , 看不懂的 可以看我前面的装饰器的讲解 。
  2. Person(fun) 相当于实例化, 只是他传递的比较特殊是个方法的引用,
  3. 首先走的是 init 方法 初始化 , 打印了 init 方法进行初始化 ,然后 把方法fun 的引用交给了私有属性 __func
  4. 实例化完成以后 把Person(fun) 实例化对象把指针传递给 fun,
  5. fun 指向实例化对象 , 当执行 fun() 的时候,就相当于 前面我们介绍的第一部分的内容,实例化方法自动调用了 call
  6. 执行call 方法里的 self.__func() , 这个 func的指针指向大家了解吗,
  7. fun的指针 传递给>func 指针又给了>__func, 所以当我们执行self.__func 的时候 就相当于 执行 fun() 也就是被装饰的方法。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值