python 学习笔记——python 装饰器(三) @functools.wraps(0

def foo():  
    print "foo"  
  
print foo.__name__  
#outputs: foo  
  
# With a decorator, it gets messy      
def bar(func):  
    def wrapper():  
        print "bar"  
        return func()  
    return wrapper  
 
@bar  
def foo():  
    print "foo"  
  
print foo.__name__  
#outputs: wrapper  
  
# "functools" can help for that  
  
import functools  
  
def bar(func):  
    # We say that "wrapper", is wrapping "func"  
    # and the magic begins  
    @functools.wraps(func)  
    def wrapper():  
        print "bar"  
        return func()  
    return wrapper  
 
@bar  
def foo():  
    print "foo"  
  
print foo.__name__  
#outputs: foo  


使用functools进行装饰的原因见下面:

1、装饰器是在Python 2.4之后才有的特性,所以请检查你的版本。
2、请记住:装饰器将会带来性能问题。
3、装饰是不可逆的。虽然已经有hacks设计出了可逆的装饰器,但是基本没人这么做。所以一旦一个函数被装饰过了,就无法还原了。
4、装饰器包装了函数,使得调试更加困难。
Python 2.5 解决上面提到的第四个问题。Python 2.5 之后,包含了一个functools模块,这个模块提供一个functools.wraps方法,这个方法将被包装的函数的name, module 和 docstring 都复制到包装好的函数上去。显然,functools.wraps也是一个装饰器

发布了37 篇原创文章 · 获赞 7 · 访问量 4万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章