这篇文章中记录说明下多个装饰器一同装饰同一个函数时的执行顺序问题。

【装饰器链】

  按照惯例,先看代码示例:

import time
def debug1(str): #传参接受类的方法
def func11(f1):
def func12(my,m,n): #原类方法有三个参数,故内层函数需要传递相同的参数
print("\n\rStarting debug1()\n\r")
f1(my,m,n)
print("\n\rStopped debug1()\n\r")
return func12 #返回内层函数
return func11 def debug2(num): #传参接受类的方法
def func21(f2):
def func22(my,m,n): #原类方法有三个参数,故内层函数需要传递相同的参数
print("\n\rStarting debug2()\n\r")
time.sleep(num)
f2(my,m,n)
print("\n\rStopped debug2()\n\r")
return func22 #返回内层函数
return func21 class test():
@debug2(3) #sleep N秒后再执行
@debug1("Steve Jobs") #打印此次的执行人员
def myAdd(self,a,b):
print(a + b) if __name__ == "__main__":
myIns=test()
myIns.myAdd(2,3)

  其执行结果如下:

  结果就像三明治夹心一样:最顶、最底都为debug2的输出,次顶、次底都为debug1的输出,最中间的夹心为myAdd的输出。

  为什么是这个样子呢?结合前两篇的介绍我们容易得知,这种简写的方式其实质是下面这种调用关系:

import time
def debug1(str): #传参接受类的方法
def func11(f1):
def func12(my,m,n): #原类方法有三个参数,故内层函数需要传递相同的参数
print("\n\rStarting debug1()\n\r")
f1(my,m,n)
print("\n\rStopped debug1()\n\r")
return func12 #返回内层函数
return func11 def debug2(num): #传参接受类的方法
def func21(f2):
def func22(my,m,n): #原类方法有三个参数,故内层函数需要传递相同的参数
print("\n\rStarting debug2()\n\r")
time.sleep(num)
f2(my,m,n)
print("\n\rStopped debug2()\n\r")
return func22 #返回内层函数
return func21 class test():
#@debug2(3) #sleep N秒后再执行
#@debug1("Steve Jobs") #打印此次的执行人员
def myAdd(self,a,b):
print(a + b) #上面两行的简写格式,其实质是下面这种调用关系:
func21=debug2(3) #因为装饰器带有参数,实际上就是函数调用,需要先执行
func11=debug1("Steve Jobs") #因为装饰器带有参数,实际上就是函数调用,需要先执行
myAdd=func11(myAdd) #此处得到的myAdd实质就是func12
myAdd=func21(myAdd) #此处得到的myAdd实质就是func22 if __name__ == "__main__":
myIns=test()
myIns.myAdd(2,3) #此时调用的其实是func22(2,3)

  其执行结果如下(跟上面的简写形式结果一致,进一步验证了我们的拆分是等价的):

  通过上述实验证明:多个装饰器同时装饰一个函数的时候,调用的原则是:由近及远

Python装饰器(3)的更多相关文章

  1. 关于python装饰器

    关于python装饰器,不是系统的介绍,只是说一下某些问题 1 首先了解变量作用于非常重要 2 其次要了解闭包 def logger(func): def inner(*args, **kwargs) ...

  2. python装饰器通俗易懂的解释!

    1.python装饰器 刚刚接触python的装饰器,简直懵逼了,直接不懂什么意思啊有木有,自己都忘了走了多少遍Debug,查了多少遍资料,猜有点点开始明白了.总结了一下解释得比较好的,通俗易懂的来说 ...

  3. Python 装饰器学习

    Python装饰器学习(九步入门)   这是在Python学习小组上介绍的内容,现学现卖.多练习是好的学习方式. 第一步:最简单的函数,准备附加额外功能 1 2 3 4 5 6 7 8 # -*- c ...

  4. python 装饰器修改调整函数参数

    简单记录一下利用python装饰器来调整函数的方法.现在有个需求:参数line范围为1-16,要求把9-16的范围转化为1-8,即9对应1,10对应2,...,16对应8. 下面是例子: def fo ...

  5. python 装饰器学习(decorator)

    最近看到有个装饰器的例子,没看懂, #!/usr/bin/python class decorator(object): def __init__(self,f): print "initi ...

  6. Python装饰器详解

    python中的装饰器是一个用得非常多的东西,我们可以把一些特定的方法.通用的方法写成一个个装饰器,这就为调用这些方法提供一个非常大的便利,如此提高我们代码的可读性以及简洁性,以及可扩展性. 在学习p ...

  7. 关于python装饰器(Decorators)最底层理解的一句话

    一个decorator只是一个带有一个函数作为参数并返回一个替换函数的闭包. http://www.xxx.com/html/2016/pythonhexinbiancheng_0718/1044.h ...

  8. Python装饰器由浅入深

    装饰器的功能在很多语言中都有,名字也不尽相同,其实它体现的是一种设计模式,强调的是开放封闭原则,更多的用于后期功能升级而不是编写新的代码.装饰器不光能装饰函数,也能装饰其他的对象,比如类,但通常,我们 ...

  9. Python装饰器与面向切面编程

    今天来讨论一下装饰器.装饰器是一个很著名的设计模式,经常被用于有切面需求的场景,较为经典的有插入日志.性能测试.事务处理等.装饰器是解决这类问题的绝佳设计,有了装饰器,我们就可以抽离出大量函数中与函数 ...

  10. python装饰器方法

    前几天向几位新同事介绍项目,被问起了@login_required的实现,我说这是django框架提供的装饰器方法,验证用户是否登录,只要这样用就行了,因为自己不熟,并没有做过多解释. 今天查看dja ...

随机推荐

  1. vue中子组件更新父组件

    当在子组件里更改了某些信息且关闭子组件后,需要父组件更新修改后的内容,该如何操作 1.$emit触发 父组件 @add="add(val)" 子组件 this.$emit('add ...

  2. Verilog基础语法总结

    去年小学期写的,push到博客上好了 Verilog 的基本声明类型 wire w1; // 线路类型 reg [-3:4] r1; // 八位寄存器 integer mem[0:2047]; // ...

  3. 用python写的一个自动卸载python包的脚本

    import osplist=os.popen("pip list") # 执行windows cmd命令,获取所有包package列表,并获取返回结果到plist#跳过第1,2行 ...

  4. Linux的IO调度程序

    Linux的IO调度机制浅析 现代计算机体系中,磁盘的速度和CPU的速度差距太大了,如果简单的将系统的IO请求按照请求的顺序进行顺序处理的话,系统的IO开销将导致系统的效率十分的低下,因此就需要将IO ...

  5. 101道Numpy、Pandas练习题

    无论是数据分析还是机器学习,数据的预处理必不可少. 其中最常用.最基础的Python库非numpy和pandas莫属,很多初学者可能看了很多教程,但是很快就把用法忘光了. 光看不练假把式,今天向大家推 ...

  6. js 十大排序算法 All In One

    js 十大排序算法 All In One 快速排序 归并排序 选择排序 插入排序 冒泡排序 希尔排序 桶排序 堆排序(二叉树排序) 基数排序 计数排序 堆排序(二叉树排序) https://www.c ...

  7. 如何使用 js 实现一个 debounce 函数

    如何使用 js 实现一个 debounce 函数 原理 防抖: 是指在指定的单位时间内,如果重复触发了相同的事件,则取消上一次的事件,重新开始计时! 实现方式 "use strict&quo ...

  8. Twitter 分享

    Twitter 分享 Twitter Share API https://twitter.com/intent/tweet?url= &text= demo ?url= https://www ...

  9. Python 2 to Python 3 convert

    Python 2 to Python 3 convert 2to3, 自动将 Python 2 代码转为 Python 3 代码 https://docs.python.org/zh-cn/2/lib ...

  10. Flutter & App

    Flutter & App Android & iOS https://flutter.dev/docs/deployment/flavors https://flutter.dev/ ...