python装饰器为什么要双层嵌套?

一个普通的装饰器应该这样写:

def log(func):
    def wrapper(*args, **kw):
        print('call %s():' % func.__name__)
        return func(*args, **kw)
    return wrapper

但是我困惑了好久,为什么中间会有个wrapper函数?

def log(func):
    print('call %s():' % func.__name__)
    return func(*args, **kw)

不也是可以实现执行函数之前输出语句么?

但是仔细看装饰器的定义,装饰器是要在我们调用这个函数的时候才会输出装饰器里面的内容,装饰器相当于实现了语句

@log
def now():
    print('2015-3-25')
now = log(now)
如果按照第二种方法写,那么在没调用now的情况下我们也会得出一条装饰器的输出语句,因为这时候log函数执行了,所以需要第一种写法来返回一个函数

你可能感兴趣的:(python装饰器为什么要双层嵌套?)