Python学习基础笔记十九——装饰器
admin
2024-04-16 21:38:17
0

装饰器的形成过程:

import timedef func1():print('in func1')start = time.time()
func1()
end = time.time()
print(end - start)

再进一步:

import timedef timer(f):          # 计算函数执行时间,将函数名作为参数start = time.time()f()                # 执行函数end = time.time()print(end - start)def func():print("Hello world!")timer(func)

第二次进化:

import timedef func():print("Hello world!")def timer(f):         # 装饰器def inner():       # 闭包start = time.time()f()           # 被装饰器函数end = time.time()print(end - start)return innerfunc = timer(func)func()

说明程序的运行过程:

第一步:def func():  func函数声明

第二步:def timer(func)  timer函数声明

第三步:func = timer(func)  先运行timer函数,传递func函数名(内存地址)

第四步:def inner():开始运行timer函数内部代码,声明inner函数

第五步:return inner: 返回inner内存地址

第六步:func = timer(func):  将timer的返回值(inner内存地址)传给func变量(实际也是内存地址,跟func函数的内存地址是一样的)

第七步:func() 开始执行func(),实际上执行的就是inner函数,因为将inner内存地址赋值给了func变量的内存地址。

第八步:start = time.time(), 开始到inner函数内部开始执行,从这步开始,获得当前系统时间赋值给start变量。

第九步:f(), 开始执行f函数,该f,就是上一层timer函数传递进来的参数func。

第十步:print("Hello world!")然后执行func函数内部代码,执行完毕,即退出func函数。

第十一步:end = time.time(), 获得当前系统时间,赋值给end变量。

第十二步:print(end - start), 然后获得两个时间时间差,并打印,到这一步,inner函数执行完毕,退出inner。

第十三步:到func()调用函数的下一行。

装饰器的作用:

不想修改函数的调用方式,但是还想在原来的函数的前后添加新功能,timer是一个装饰器函数,只是对一个函数有一些装饰作用。

从上面的代码可见,timer是装饰器函数,f() 是被装饰的函数。

进一步变化:

import timedef timer(f):def inner():start = time.time()f()end = time.time()print(end - start)return inner@timer             # 装饰器函数名
def func():        # 被装饰的函数名print("Hello world!")# func = timer(func)func()

注意其中的@timer的位置。

再进一步,注意其中对返回值的处理:

import timedef timer(f):def inner():start = time.time()ret = f()end = time.time()print(end - start)return retreturn inner@timer             # 装饰器函数名
def func():        # 被装饰的函数名print("Hello world!")return '新年好'# func = timer(func)ret = func()
print(ret)

如果func有返回值,看看装饰器函数timer中是怎么处理的,然后调用的时候也要注意下这个返回值。

再进一步:

import timedef timer(f):def inner(a):start = time.time()ret = f(a)end = time.time()print(end - start)return retreturn inner@timer             # 装饰器函数名
def func(a):        # 被装饰的函数名print("Hello world!", a)return '新年好'# func = timer(func)ret = func(1)
print(ret)

装饰带参数函数的装饰器。有了对带参数的处理。

进一步变化, 万能参数:

import timedef timer(f):def inner(*args, **kwargs):start = time.time()ret = f(*args, **kwargs)end = time.time()print(end - start)return retreturn inner@timer             # 装饰器函数名
def func(a):        # 被装饰的函数名print("Hello world!", a)return '新年好'@timer             # 装饰器函数名
def func(a, b):        # 被装饰的函数名print("Hello world!", a, b)return '新年好'# func = timer(func)ret = func(1)
print(ret)

最后,我们再将装饰器简化:

def wrapper(f):                    # 装饰器wrapperdef inner(*args, **kwargs):  '''在装饰前要做的事情'''  ret = f(*args, **kwargs)   # 被装饰的函数'''在装饰后要做的事情'''return retreturn inner@wrapper                           # 装饰器函数名
def func(a, b):                    # 被装饰的函数

这个就是一个装饰器固定模式。

原则:开放封闭原则:

开放:对扩展是开放的。

封闭:对修改是封闭的。

目的是维护代码的稳定性,那么这个就是装饰器存在的意义。

相关内容

热门资讯

4家银行AIC现身存储巨头股东... 近日,资本市场热度颇高的两家存储巨头长鑫科技集团股份有限公司(以下简称“长鑫科技”)、长江存储控股股...
8元无限续杯、0元看电影、老字... 城市的烟火暖意,藏在亲民的消费场景里,也藏在老地标的新生蜕变中。粤汉码头火车旁新开竹林茶馆,8元就能...
2026年水利工程新趋势,这些... 随着全球气候变化和城市化进程的加速,水利工程在保障水资源供给、改善生态环境以及提升人民生活质量中的作...
原创 发... 这几年,身边越来越多人开始换一种活法:不急着买房,不执着“上车”,反而愿意把钱拿去租一套更舒服、更体...
小红书入场Skill分发,B站... 来源:界面新闻 文丨AI价值官 星野 编辑丨美圻 过去半年,Skill 这个词在AI圈的出现...
2026年福州企业门户网站建设... 本篇将回答的核心问题 在数字化转型加速的2026年,企业门户网站建设应遵循哪些核心评估标准,以确保投...
原创 今... 今日金价:2026年5月22日注意了!黄金或现历史类似回调走势 5月22日,金市又热闹起来了,咱们看...
雷军发布YU7 GT、YU7标... 5月21日,小米人车家全生态新品发布会在北京举办,小米集团创始人、董事长兼CEO雷军正式发布小米YU...
留神峪煤矿瓦斯爆炸事故发布会:... 昨晚,山西留神峪煤矿发生瓦斯爆炸,造成重大人员伤亡。今天,当地召开新闻发布会,现场全体默哀。会上介绍...
原创 修... 修复资产负债表,日本花了几十年。 自上世纪90年代初泡沫经济破裂后,日本陷入了长达三十年的通缩螺...
2026年小红书效果化种草白皮... 2026 年小红书正式迈入种草效果化时代,这是品牌追求预算确定性回报与平台升级为消费决策、用户信任场...
连续18年获“全国文化企业30... 南都讯 记者钟欣5月21日,第二十二届中国(深圳)国际文化产业博览交易会开幕。展会期间,光明日报社和...
荣耀确认IPO未终止!开放员工... 5月22日,荣耀因股改满一年未完成IPO,按约定正式开放员工持股退出通道。据《财闻》报道称,当日16...
易方达蓝筹精选有新变动:增聘2... 《每日经济新闻》记者获悉,继景顺长城、中欧等多家基金公司旗下百亿基金经理产品调整后,易方达基金也迎来...
光储龙头,又翻倍了 去年海外光储赛道最受关注的公司,毫无疑问是阳光电源,市值重回巅峰,风光无限。 但今年一季度业绩突然失...
中企出海报告在静安发布,七成受... 来源:滚动播报 (来源:上观新闻) 昨天,在上海静安举办的澳洲会计师公会出海论坛暨澳洲注册会计师颁...
京蒙协作延链强链 科右中旗牛产... 初夏时节,走进内蒙古华阳牛业科技集团有限公司屠宰加工车间,自动化生产线高效运转。作为京蒙协作产业帮扶...
原创 中... 最近发布了一份有关新一线城市魅力的榜单。榜单按照商业资源聚集度、城市枢纽性、城市人活跃度这五个方面来...
突然,全线跳水!超16万人爆仓 来源:宁波晚报 5月23日,被视作反映市场风险偏好指标的加密货币持续跳水。 截至发稿,比特币大跌3....
基民懵了!说好的科技行情,结果... 每经记者:叶峰 每经编辑:赵云 本周股指冲高回落,沪深两市股票型ETF和跨境型ETF合计净流出729...