标签:war import 现在 赋值 延迟 重复 一个 添加 网络
import time
# def index():
# ‘‘‘有很多代码.....‘‘‘
# time.sleep(2) # 模拟的网络延迟或者代码效率
# print(‘欢迎登录博客园首页‘)
#
# def dariy():
# ‘‘‘有很多代码.....‘‘‘
# time.sleep(3) # 模拟的网络延迟或者代码效率
# print(‘欢迎登录日记页面‘)
# 版本一有问题: 如果测试别人的代码,必须重新赋值粘贴。
# start_time = time.time()
# index()
# end_time = time.time()
# print(end_time-start_time)
#
# start_time = time.time()
# dariy()
# end_time = time.time()
# print(end_time-start_time)
版本二:利用函数,解决代码重复使用的问题
import time
def index():
‘‘‘有很多代码.....‘‘‘
time.sleep(2) # 模拟的网络延迟或者代码效率
print(‘欢迎登录博客园首页‘)
# index()
def dariy():
‘‘‘有很多代码.....‘‘‘
time.sleep(3) # 模拟的网络延迟或者代码效率
print(‘欢迎登录日记页面‘)
def timmer(f): # f= index
start_time = time.time()
f() # index()
end_time = time.time()
print(f‘测试本函数的执行效率{end_time-start_time}‘)
timmer(index)
版本二还是有问题: 原来index函数源码没有变化,给原函数添加了一个新的功能测试原函数的执行效率的功能。
满足开放封闭原则么?原函数的调用方式改变了。
版本三:不能改变原函数的调用方式。
# import time
# def index():
# ‘‘‘有很多代码.....‘‘‘
# time.sleep(2) # 模拟的网络延迟或者代码效率
# print(‘欢迎登录博客园首页‘)
#
# def timmer(f): # f = index (funciton index123)
# def inner(): # inner :(funciton inner123)
# start_time = time.time()
# f() # index() (funciton index123)
# end_time = time.time()
# print(f‘测试本函数的执行效率{end_time-start_time}‘)
# return inner # (funciton inner123)
# timmer(index) # index()
# ret = timmer(index) # inner
# ret() # inner()
# index = timmer(index) # inner (funciton inner123)
# index() # inner()
版本四:具体研究
import time
def index():
‘‘‘有很多代码.....‘‘‘
time.sleep(2) # 模拟的网络延迟或者代码效率
print(‘欢迎登录博客园首页‘)
def timmer(f):
f = index
# f = <function index at 0x0000023BA3E8A268>
def inner():
start_time = time.time()
f()
end_time = time.time()
print(f‘测试本函数的执行效率{end_time-start_time}‘)
return inner
index = timmer(index)
index()
版本五:python做了一个优化;提出了一个语法糖的概念。 标准版的装饰器
import time
# timmer装饰器
def timmer(f):
def inner():
start_time = time.time()
f()
end_time = time.time()
print(f‘测试本函数的执行效率{end_time-start_time}‘)
return inner
# @timmer # index = timmer(index)
def index():
‘‘‘有很多代码.....‘‘‘
time.sleep(0.6) # 模拟的网络延迟或者代码效率
print(‘欢迎登录博客园首页‘)
return 666
ret = index()
print(ret)
def dariy():
‘‘‘有很多代码.....‘‘‘
time.sleep(3) # 模拟的网络延迟或者代码效率
print(‘欢迎登录日记页面‘)
dariy()
# index = timmer(index)
# index()
# dariy = timmer(dariy) @timmer
dariy()
版本六:被装饰函数带返回值
import time
# timmer装饰器
def timmer(f):
# f = index
def inner():
start_time = time.time()
# print(f‘这是个f():{f()}!!!‘) # index()
r = f()
end_time = time.time()
print(f‘测试本函数的执行效率{end_time-start_time}‘)
return r
return inner
@timmer # index = timmer(index)
def index():
‘‘‘有很多代码.....‘‘‘
time.sleep(0.6) # 模拟的网络延迟或者代码效率
print(‘欢迎登录博客园首页‘)
return 666
# 加上装饰器不应该改变原函数的返回值,所以666 应该返回给我下面的ret,
# 但是下面的这个ret实际接收的是inner函数的返回值,而666返回给的是装饰器里面的
# f() 也就是 r,我们现在要解决的问题就是将r给inner的返回值。
ret = index() # inner()
print(ret)
版本七:被装饰函数带参数
import time
# timmer装饰器
def timmer(f):
# f = index
def inner(*args,**kwargs):
# 函数的定义:* 聚合 args = (‘李舒淇‘,18)
start_time = time.time()
# print(f‘这是个f():{f()}!!!‘) # index()
r = f(*args,**kwargs)
# 函数的执行:* 打散:f(*args) --> f(*(‘舒淇‘,18)) --> f(‘舒淇‘,18)
end_time = time.time()
print(f‘测试本函数的执行效率{end_time-start_time}‘)
return r
return inner
@timmer # index = timmer(index)
def index(name):
‘‘‘有很多代码.....‘‘‘
time.sleep(0.6) # 模拟的网络延迟或者代码效率
print(f‘欢迎{name}登录博客园首页‘)
return 666
index(‘纳钦‘) # inner(‘纳钦‘)
@timmer
def dariy(name,age):
‘‘‘有很多代码.....‘‘‘
time.sleep(0.5) # 模拟的网络延迟或者代码效率
print(f‘欢迎{age}岁{name}登录日记页面‘)
dariy(‘舒淇‘,18) # inner(‘舒淇‘,18)
标准版的装饰器;
def wrapper(f):
def inner(*args,**kwargs):
‘‘‘添加额外的功能:执行被装饰函数之前的操作‘‘‘
ret = f(*args,**kwargs)
‘‘‘‘添加额外的功能:执行被装饰函数之后的操作‘‘‘
return ret
return inner
标签:war import 现在 赋值 延迟 重复 一个 添加 网络
原文地址:https://www.cnblogs.com/wyh0717/p/12952282.html