python使用装饰器记录函数执行次数


def set_func(func):
    num = [0]   # 闭包中外函数中的变量指向的引用不可变
    def call_func():
        func()
        num[0] += 1
        print("执行次数",num[0])
    return call_func

# 待测试方法
@set_func
def test():
    pass

test()
test()
test()

# 执行次数 1
# 执行次数 2
# 执行次数 3

使用nonlocal 访问修改外部函数变量

def set_func(func):
    num = 0   # 闭包中外函数中的变量指向的引用不可变
    def call_func():
        func()
        nonlocal num # 使用nonlocal 访问修改外部函数变量
        num += 1
        print("执行次数",num)
    return call_func

# 待测试方法
@set_func
def test():
    pass

test()
test()
test()

# 执行次数 1
# 执行次数 2
# 执行次数 3
  • 9
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Python 装饰在许多场景中都可以发挥作用,下面列举了一些常见的使用场景: 1. 日志记录装饰可以用于在函数执行前后记录日志信息,如函数的输入参数、执行时间、返回值等,方便调试和追踪问题。 2. 认证和权限控制:装饰可以用于验证用户身份或检查权限,确保只有经过授权的用户能够访问特定的函数或页面。 3. 缓存:装饰可以用于缓存函数的计算结果,避免重复计算,提高性能。常见的应用包括计算密集型函数、网络请求等。 4. 输入验证和参数校验:装饰可以用于对函数的输入参数进行验证和校验,确保输入参数符合要求,提高程序的健壮性和可靠性。 5. 计时和性能分析:装饰可以用于统计函数执行的时间,帮助分析程序的性能瓶颈,并进行优化。 6. 重试机制:装饰可以用于在函数执行失败时自动重试一定次数,增加程序的容错性。 7. 编码转换和数据序列化:装饰可以用于将函数的返回值进行编码转换或数据序列化,方便网络传输或持久化存储。 8. 异常处理:装饰可以用于捕获函数执行过程中的异常,并进行相应的处理,如记录日志、返回默认值等。 9. 单例模式:装饰可以用于将类转换为单例模式,确保只有一个实例对象存在。 需要注意的是,装饰的应用不仅限于上述场景,可以根据具体需求和创意进行扩展和组合。装饰提供了一种优雅且灵活的方式来修改函数或类的行为,可以有效地减少重复代码,并提高代码的可读性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值