码迷,mamicode.com
首页 > 编程语言 > 详细

python装饰器

时间:2017-04-09 13:54:20      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:函数   理解   ret   class   执行   实现   log   wrap   pytho   

def log(text):
    print(1)
    def deractor1(func):
        print(2)
        def wrapper(*args,**kw):
            print(3)
            func(*args,**kw)
            print(4)
        return wrapper
    return deractor1

def Mylog():
    print("my log")

 

上面是定义的一个装饰器,装饰器都使用闭包实现

执行log("ddd"),只会打印1,也就是当前返回deractor1这个函数。

如果执行log("dddddd")(Mylog),就会打印1,2,也就是当前返回的函数是wrapper。

如果log("dddddd")(Mylog)(),就会打印1,2,3,my log,4,也就是执行了wrapper函数。该函数装饰了Mylog函数。

深刻理解python的闭包。

  

python装饰器

标签:函数   理解   ret   class   执行   实现   log   wrap   pytho   

原文地址:http://www.cnblogs.com/MrZhang1/p/6684272.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!