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

【装饰器链】

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

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. python to exe

    使用pyinstaller 打包 文件结构如下 命令行cd 进入 project文件夹 ,然后 命令 pyinstaller -F main.py 即可打包文件为一个完整的exe.(不含DLL等)

  2. Redis内存管理中的LRU算法

    在讨论Redis内存管理中的LRU算法之前,先简单说一下LRU算法: LRU算法:即Least Recently Used,表示最近最少使用页面置换算法.是为虚拟页式存储管理服务的,是根据页面调入内存 ...

  3. Graphviz - Graph Visualization Software 开源可视化绘图工具(visio 类)

    http://www.graphviz.org/Download_windows.php Welcome to Graphviz Available translations:  Romanian,  ...

  4. 使用 js 实现十大排序算法: 基数排序

    使用 js 实现十大排序算法: 基数排序 基数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  5. codepen iframe theme id

    codepen iframe theme id iframe css theme demos See the Pen css margin collapsing (1. 相邻兄弟元素) by xgqf ...

  6. Alexa website ranking

    Alexa website ranking The top 500 sites on the web https://www.alexa.com/topsites https://www.alexa. ...

  7. MacBook Pro 关闭触控板

    MacBook Pro 关闭触控板 https://support.apple.com/zh-cn/HT204895 https://support.apple.com/zh-cn/HT203171 ...

  8. NGK生态所即将启程!助力NGK公链建立全方位区块链生态系统!

    据NGK官方消息,NGK生态所将暂定于2月15日正式上线.据了解,这是全球首个基于公链打造的生态所,也是NGK生态重要的应用之一. 此前,NGK灵石团队CTO通过多方媒体透露,NGK生态所采用去中心化 ...

  9. 为什么说NGK的去中心化预言机越来越受欢迎?

    2020年区块链市场非常火热,从年初的交易所杠杆,到Defi热潮,一波连着一波,风向不断切换,很多人无奈感叹跟不上时代,很多人欢欣雀跃登上了早班车.随着Defi的不断火热,预言机也进入了大众视野.NG ...

  10. 统一数据管理工具 —— CloudQuery v1.3.3 上线!

    前言 岁末临近,让我们跟随着新春的脚步,一起去看看 CloudQuery 今年最后一次更新吧! 新增功能 一.Oracle - 查看表结构 Oracle 数据源中,可查看各表结构信息(列详情和表注释等 ...