鱼C论坛

 找回密码
 立即注册
查看: 1697|回复: 4

[已解决]多个装饰器调用问题

[复制链接]
发表于 2022-3-31 18:09:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
import time

def logger(msg):
    def time_master(func):
        def call_func():
            print(msg+'开始执行程序')
            start  = time.time()
            func()
            stop  = time.time()
            print('结束执行程序')
            print(f'执行时间{(stop - start):.2f}')
        return call_func
    return time_master

@logger(msg = 'b')
@logger(msg = 'a')
def myfunc():
    time.sleep(1)
    print('正在执行1秒休息')

myfunc()

执行结果
b开始执行程序
a开始执行程序
正在执行1秒休息
结束执行程序
执行时间1.02
结束执行程序
执行时间1.06
为啥会是这个结果,不应该是先执行a再执行b么
希望各位前辈答疑解惑,感谢感谢!
最佳答案
2022-3-31 18:17:52
本帖最后由 isdkz 于 2022-4-1 14:43 编辑

@logger(msg = 'b')
@logger(msg = 'a')
def myfunc():
    time.sleep(1)
    print('正在执行1秒休息')

相当于

myfunc = logger(msg = 'b')(logger(msg = 'a')(myfunc))

所以先是输出 b 再输出 a

@装饰器
def 函数:

是相当于  函数 = 装饰器(函数)
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-3-31 18:17:52 | 显示全部楼层    本楼为最佳答案   
本帖最后由 isdkz 于 2022-4-1 14:43 编辑

@logger(msg = 'b')
@logger(msg = 'a')
def myfunc():
    time.sleep(1)
    print('正在执行1秒休息')

相当于

myfunc = logger(msg = 'b')(logger(msg = 'a')(myfunc))

所以先是输出 b 再输出 a

@装饰器
def 函数:

是相当于  函数 = 装饰器(函数)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-1 10:06:38 | 显示全部楼层
isdkz 发表于 2022-3-31 18:17
@logger(msg = 'b')
@logger(msg = 'a')
def myfunc():

前辈,您太厉害了,就是相当于myfunc = logger(msg = 'b')(logger(msg = 'a')(myFunc))
但是我不明白这个程序为啥是这样运行的呜呜呜呜呜
logger(msg = 'b')这是最外层返回值是time_master
相当于time_master(logger(msg = 'a')(myFunc))
是不是把logger(msg = 'a')(myFunc)当作func放入call_func()中调用
print(msg+'开始执行程序')=b开始执行程序
func()=a开始执行程序
            正在执行1秒休息
            结束执行程序
            执行时间1.02
print('结束执行程序')=结束执行程序
print(f'执行时间{(stop - start):.2f}')=执行时间1.05
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-1 10:12:18 | 显示全部楼层
李二蛋 发表于 2022-4-1 10:06
前辈,您太厉害了,就是相当于myfunc = logger(msg = 'b')(logger(msg = 'a')(myFunc))
但是我不明白这 ...

对的,@ 是一个语法糖,它的本质就是将被它修饰的函数传进去,

然后将它的返回值替换原来的函数,你只要记住下面这个就不会那么云里雾里了

@装饰器
def 函数:
    ...


相当于

def 函数:
    ...
函数 = 装饰器(函数)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-1 11:19:00 | 显示全部楼层
isdkz 发表于 2022-4-1 10:12
对的,@ 是一个语法糖,它的本质就是将被它修饰的函数传进去,

然后将它的返回值替换原来的函数,你只 ...

好嘞,感谢前辈哈
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-29 07:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表