Python的解释器执行顺序

  初学python,对装饰器的执行顺序,可能有很多人不太清晰。
  下面我们先看一段装饰器的代码:
import time
def ceshi():
    print("hello world")
def shuchu():
    print("good bye")
def dss(func):
    ceshi()
    def wrapper(*args, **kwargs):
        print("我是小坏蛋")
        start_time = time.time()
        func()
        end_time = time.time()
        print(str(end_time - start_time)+"5")
        shuchu()
    return wrapper
 @dss              #@dss的作用是 func=dss(func)  为func装饰返回
def func():
    time.sleep(0.8)
func()# 函数调用

执行结果为:
在这里插入图片描述
可发现为先执行wrapper外部的函数,在执行wrapper内部的函数。

当一个函数有多个装饰器的时候:

import time
def ceshi():
    print("hello world")
def shuchu():
    print("good bye")
def dss(func):
    ceshi()
    def wrapper(*args, **kwargs):
        print("我是小坏蛋")
        start_time = time.time()
        func()
        end_time = time.time()
        print(str(end_time - start_time)+"5")
        shuchu()
    return wrapper
def dsn(func):
    shuchu()
    print("521")
    def mvc():
        print("woshinidebaba")
        start =time.time()
        func()
        end=time.time()
        print(str(end-start)+"sf")
        print("shaerzo")
    return  mvc

@dss
@dsn
def func():
    time.sleep(0.8)


func()# 函数调用

在debug窗口下单步执行的结果如下:
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

由运行的结果可以得出:当一个函数有多个装饰器的时候,在被装饰函数的外部,会由近及远的进行,在装饰函数内部会顺序执行。当执行到func()原函数时。重新回到由近及远的执行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值