装饰器

1. 开放封闭原则

扩展是开放的,增加新的功能;修改源码(修改已经实现的功能)是封闭的。
在不改变源码及调用方式的前提下额外增加新的功能。
# 版一:
import time
start_time = time.time() #起始时间
def func():
time.sleep(2) #睡眠,模拟网络延迟
print("我要飞")
func()
print(time.time()- start_time) # 打印执行世界 # 版二:
import time
def times(s):
start_time = time.time()
s()
print(time.time()- start_time)
def foo():
time.sleep(2)
print("我要飞")
times(foo) #改变了调用方式 # 版三(初版装饰器):
import time
def times(s):
def inner():
start_time = time.time()
s()
print(time.time()- start_time)
return inner
def func():
time.sleep(1)
print("我也要飞")
func = times(func) # 不需改调用方式
func() # 版四(升级):
def wrapper(f):
def inner(a): #加入参数
f(a)
return inner # 切记不加括号 def func(a): # 加参数
print(f"这是{a}的函数")
func = wrapper(func)
func("alex") # 升级 万能传参:
import time
def wrapper(f):
def inner(*args,**kwargs):
start_time = time.time()
f(*args,**kwargs)
print(time.time() - start_time)
return inner # 切记不加括号 def func(*args,**kwargs): # 加形参
time.sleep(1)
print(f"这是{args,kwargs}的函数")
func = wrapper(func)
func("alex",1,2,a = 3,b = 4) def foo(*args,**kwargs): # 加形参
time.sleep(2)
print(f"这是{args,kwargs}的函数")
foo = wrapper(foo)
foo("meet",1,2,a = 3,b = 4) #语法糖 放在被装饰函数的上方
#替代func = wrapper(func) 和 foo = wrapper(foo) import time
def wrapper(f):
def inner(*args,**kwargs):
start_time = time.time()
f(*args,**kwargs)
print(time.time() - start_time)
return inner # 不加括号
@wrapper #语法糖
def func(*args,**kwargs): # 加形参
time.sleep(1)
print(f"这是{args,kwargs}的函数")
# func = wrapper(func)
@wrapper #语法糖
def foo(*args,**kwargs): # 加形参
time.sleep(2)
print(f"这是{args,kwargs}的函数")
# foo = wrapper(foo) func("alex",1,2,a = 3,b = 4)
foo("meet",5,6,a = 7,b = 8) # 标准版:
import time
def wrapper(f):
def inner(*args,**kwargs):
start_time = time.time()
ret = f(*args,**kwargs)
print(time.time() - start_time)
return ret #增加返回值
return inner # 切记不加括号
@wrapper #语法糖
def func(*args,**kwargs): # 加形参
time.sleep(1)
print(f"这是{args,kwargs}的函数")
return "这是alex的返回"
print(func("alex",1,2,a = 3,b = 4)) # 会打印"这是alex的返回"
#语法糖  放在被装饰函数的上方

#标准版的装饰器:
def wrapper(func):
def inner(*args,**kwargs):
'''执行被装饰函数之前的操作'''
ret = func(*args,**kwargs)
'''执行被装饰函数之后的操作'''
return ret # 返回inner(),也就是func()打印
return inner
@wrapper # 相当于 func = wrapper(func)
def func(*args,**kwargs)
print(args,kwargs)
return "返回的内容" # 返回ret
print(func()) # 能够打印返回值,也可以传参

最新文章

  1. 张小龙宣布微信小程序1月9日发布,并回答了大家最关心的8个问题
  2. androidstdio偶遇一
  3. JAVA设计模式--单例模式
  4. 微信公众号网页开发-jssdk config配置参数生成(Java版)
  5. Python基础篇【第8篇】: Socket编程(二)SocketServer
  6. 作业七:团队项目——Alpha版本冲刺阶段-10
  7. iOS6、7、8、9新特性汇总和适配说明
  8. JLOI2016 方
  9. atitit.提升备份文件复制速度(4) ---数据挖掘 获取回收站文件列表
  10. 关于Bitcode的探索
  11. Stunnix C++ Obfuscator使用简介
  12. 我的博客已搬迁到http://www.lsworks.net
  13. Apache + Tomcat集群配置详解 (1)
  14. Scala学习笔记--抽象成员
  15. Jar包转成Dll的方式(带嵌套的jar也能做) (转)
  16. linux之有名管道
  17. 【Alpha】——Fourth Scrum Meeting
  18. 深度剖析PHP序列化和反序列化
  19. git生成ssh公钥方法--远程连接github仓库
  20. java 每间隔一段时间执行一段代码

热门文章

  1. [WPF自定义控件库]自定义Expander
  2. java练习---14
  3. 【Arduino】37种传感器系列实验(4)---振动传感器模块
  4. java的System.currentTimeMillis()和System.nanoTime
  5. Linux中bash shell环境变量
  6. Jenkins安装插件问题
  7. GStreamer流媒体知识介绍
  8. kubernetes离线包分析
  9. Codeforces Round #527 (Div. 3) 总结 A B C D1 D2 F
  10. Css3动画效果,彩色文字效果,超简单的loveHeart