时间:2021-05-22
一、闭包
闭包从形式上来说是在外部函数中定义内部函数,并且内部函数引用了外部函数的变量,此变量叫做自由变量。
或者说是将组成函数的语句和这些语句的执行环境打包在一起。
闭包满足的条件:
必须有一个内嵌函数
内嵌函数必须使用外部函数的变量
外部函数的返回值必须是内嵌函数
外部函数closure中有变量value和内部函数fun,并且内部函数fun引用了自由变量value,当执行cc = closure()时,就产生了一个闭包fun,该闭包持有只有变量value,当函数closure生命周期结束后,value依然存在,因为它被闭包引用了。
二、装饰器
装饰器其实就是闭包的应用,只不过其传递的是函数。
def add_time(fun): def wrapper(): print('time: 12:00') return fun() return wrapperdef add_format(fun): def wrapper(): print('\n') return fun() return wrapper@add_format #等同于demo = add_format(add_time(demo))@add_time #等同于 demo = add_time(demo)def demo(): return 'hello world!'另外,装饰器会将demo函数的元信息丢失,例如__name__等等。
例如demo函数的__name__会由'demo'变成了'wrapper',这时需要用到functools库,在wrapper函数前加上@functools.wraps(fun):
import functoolsdef add_time(fun): @functools.wraps(fun) def wrapper(): print('time: 12:00') return fun() return wrapperdef add_format(fun): @functools.wraps(fun) def wrapper(): print('\n') return fun() return wrapper@add_format #等同于demo = add_format(add_time(demo))@add_time #等同于 demo = add_time(demo)def demo(): return 'hello world!'例如给任意函数加上打印时间的功能的装饰器:
def metric(fn): start=time.time() @functools.wraps(fn) def wrapper(*args,**kw): end=time.time() print('%s executed in %s ms' % (fn.__name__,start-end)) return fn(*args,**kw) return wrapper以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python装饰器decorator用法。分享给大家供大家参考。具体分析如下:1.闭包(closure)闭包是Python所支持的一种特性,它让在
详解Python中LEGB和闭包及装饰器LEGBL>E>G?BL:local函数内部作用域E:enclosing函数内部与内嵌函数之间G:global全
这篇文章主要介绍了Python@property装饰器原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
本文实例讲述了python装饰器原理与用法。分享给大家供大家参考,具体如下:你会Python嘛?我会!那你给我讲下Python装饰器吧!Python装饰器啊?我
一般来说闭包这个概念在很多语言中都有涉及,本文主要谈谈python中的闭包定义及相关用法。Python中使用闭包主要是在进行函数式开发时使用。详情分析如下:一、