python装饰器的特性原理详解
这篇文章主要介绍了python装饰器的特性原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
今天发现了装饰器的另一种用法,下面就先上代码:
data_list=[] defdata_item(func): data_list.append(func) returnfunc @data_item deffoo(): return1 @data_item deffoo1(): return2 @data_item deffoo3(): return3 defmax_item(): result=max(i()foriindata_list) returnresult if__name__=='__main__': item=max_item() print(item)
代码很简单就是,定义三个foo开头的函数,每个foo函数输出不一样的数字,都通过装饰器data_item进行修饰,最后通过max_item函数,执行一系列逻辑获取结果。
这里有个容易被忽略的点,那就是装饰器实际是在执行max_item()之前就执行了。
所以,如果你打印下data_list你会发现它是有值的。
[, , ]
即列表里面已经有三个被装饰器修饰的函数了,然后在
max(i()foriindata_list)
的i()阶段这三个函数执行了,得到了结果(1,2,3),然后最后取它们的max值即3。
什么场景会用到呢,一般对于传入一个值然后多种处理方案,选择其中最佳方案的时候可以考虑使用这种方法。
emmm,装饰器还是挺有意思的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。