Python
的装饰器
类似于Java的注解
,可以在不侵入原有代码的基础上进行额外的操作,比如记录日志
等操作。
底层的实现相当于将一个函数传入了另一个函数,然后执行自己想要的操作。
这类问题比较简单,只需要在装饰器函数中直接调用原函数即可
def log(func):
"""
传入所装饰函数的参数值
"""
def inner_log(*args, **kw):
print("Call: {}".format(func.__name__))
return func(*args, **kw)
return inner_log
@log
def timer(a):
print(a)
timer(2)
为了在装饰器内传入参数,我们需要额外多定义一层函数
def get_log(*args, **kw):
"""
装饰器如果想要带有参数,需要多定义一层函数
"""
print(args[0])
"""
装饰函数额外处理逻辑
"""
def log(func):
"""
传入所装饰函数的参数值
"""
def inner_log(*args, **kw):
print("Call: {}".format(func.__name__))
return func(*args, **kw)
return inner_log
return log
@get_log(3)
def timer(a):
print(a)
timer(2)