Python 多个装饰器_执行顺序的深刻剖析

二 多个装饰器_执行顺序的深刻剖析

多个装饰器

有时候,我们需要多个装饰器修饰一个函数。比如:需要增加日志功能、增加执行效率测试功能。

装饰器函数的执行顺序是分为(被装饰函数)定义阶段和(被装饰函数)执行阶段的,装饰器函数在被装饰函数定义好后立即执行

  • 在函数定义阶段:执行顺序是从最靠近函数的装饰器开始,自内而外的执行
  • 在函数执行阶段:执行顺序由外而内,一层层执行

【示例】多个装饰器执行顺序

@mylog
@cost_time
# 函数定义阶段:
# 相当于:
# fun2 = cost_time(fun2)
# fun2 = mylog(fun2)
# 也相当于:
# fun2 = mylog(cost_time(fun2))
# 定义阶段:先执行cost_time函数,再执行mylog函数
def fun2():
    pass#调用执行阶段
#先执行mylog的内部函数,再执行cost_time的内部函数
fun2()

【示例】增加日志和执行计时功能的装饰器

import time
​
def mylog(func):
  print("mylog start")
  def infunc():
    print("日志纪录 start")
    func()
    print("日志纪录 end")print("mylog end")
  return infunc
​
def cost_time(func):
  print("cost time start")
  def infunc():
    print("开始计时..")
    start = time.time()
    func()
    end = time.time()
    print(f"耗费时间:{end-start}")
    return end-start
​
  print("cost time end")
  return infunc
​
@mylog
@cost_time
# 相当于:
# fun2 = cost_time(fun2)
# fun2 = mylog(fun2)
# 也相当于:
# fun2 = mylog(cost_time(fun2))
def fun2():
  print("使用功能2")
  time.sleep(2)
  print("使用功能22")
​
fun2()

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

留不住的人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值