python 函数装饰器 闭包函数

知识点

1, 闭包函数,传入参数和返回值都是函数
2, 闭包函数的返回值函数是对传入函数的增强

没入门之前看这个知识点可能一头雾水,悟了以后就会认同的, 所以先记在心里就行.

并且装饰器也是python的一种语法糖.

 

它经常用于有切面需求的场景,比如:插入日志、性能测试、事务处理、缓存、权限校验等场景。

装饰器是解决这类问题的绝佳设计,有了装饰器,我们就可以抽离出大量与函数功能本身无关的雷同代码并继续重用。

概括的讲,装饰器的作用就是为已经存在的对象添加额外的功能。

 

推导过程就不一一列举了, 网上资料很多, 就不搬运过来了.  

自己写的一个用于计算函数所用时间的源码如下

def plus_func(func_name):
    """
    闭包函数,传入参数和返回值都是函数
    闭包函数的返回值函数是对传入函数的增强
    """
    def inner_func(*args, **kwargs):
        start_time = time.time()  # 记录开始时间
        result = func_name(*args, **kwargs)  # 执行原函数
        end_time = time.time()  # 记录结束时间
        use_time = round(end_time - start_time, 2)  # 精确到0.01s
        logging.info("{}用时:{}s".format(func_name, use_time))
        return result

    return inner_func

 

在其他函数的前面引用即可使用

@MyGlobal.plus_func
def check_surf(self, netbars, start_time, end_time):
"""
网址浏览轨迹查询
"""

 

上一篇:Analysis of container and Injection in Java, their history and future.


下一篇:L249 语法