快速理解Python装饰器

话不多说,直接上重点:

本质:Python函数
功能:可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象
主要需求场景:性能测试、插入日志、事务处理、缓存、权限校验等
优势:可以抽离出大量与函数功能本身无关的雷同代码并继续重用,即:为已经存在的对象添加额外的功能

实验代码:

# 初级版
def use_logging(func):
    def wrapper(*args, **kwargs):
        # logging.warning("{} is running...".format(func.__name__))
        print("{} is running...".format(func.__name__))
        return func(*args, **kwargs)
    return wrapper

def bar():
    print("I am a bar")

# bar = use_logging(bar)
# bar()

# 标准版
@use_logging
def foo():
    print("I am a good boy")
foo()
print("*"*20)

# 带参数装饰器
def use_logging_v2(level):
    def decorate(func):
        def wrapper(*args, **kwargs):
            # logging.warning("{} is running...".format(func.__name__))
            print("{} is running...".format(func.__name__))
            return func(*args, **kwargs)
        return wrapper
    return decorate

@use_logging_v2(level=3)
def brother():
    print("I am a bigger boy")

brother()

# 性能分析监视器
def calc_time(func):
    def wrapper(*args, **kwargs):
        print("This is {} spent time".format(func.__name__), end=':')
        t1 = time.time()
        func(*args, **kwargs)
        t2 = time.time()
        print(t2-t1)
    return wrapper

@calc_time
def worker(steps):
    walks = [1] * steps

@calc_time
def doctor(steps):
    walks = [1 for i in range(steps)]

nums = 100000000
print("*"*20)
worker(nums)
doctor(nums)

结果展示:

 

posted @ 2021-04-16 16:01  今夜无风  阅读(53)  评论(0编辑  收藏  举报