zoukankan      html  css  js  c++  java
  • 快速理解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)

    结果展示:

    时刻记着自己要成为什么样的人!
  • 相关阅读:
    【0003】与随机数有关的一些问题
    【0001】排序法与查找方式
    【0002】斐波那契数列,迷宫,汉诺塔
    【0001】C程序的编译过程
    django学习——request.POST.get(‘key’) 、 request.GET.get('key', '')
    django 删除数据库表后重新同步的方法
    Django链接mysql数据库报错1064
    sql练习题
    jmeter连接数据库
    购物车程序练习
  • 原文地址:https://www.cnblogs.com/demo-deng/p/14667381.html
Copyright © 2011-2022 走看看