装饰器的知识点储备:
1 作用域
2 高阶函数
3 闭包
内部函数,对外部作用作用域的变量进行了引用,该内部函数就认为是闭包,
def outer():
x=10
def inner():
print(x)
return inner #inner 函数就是一个闭包,闭包函数可以脱离环境 调用
f = outer()
f() 这里还能找到 x变量
闭包:函数块+定义函数时的环境
###########
开放封闭原则
当一个函数已经实现了功能,且有很多模块都在调用的时候,一旦有新需求,一般不对该函数进行源代码修改,因为
如果产生问题会导致所有调用模块跟着出错,一般在外部进行功能扩展。
########
装饰器
##最开始思路:将计算时间单独设计一个函数,然后再计算那个函数的执行时间时,调用该函数。
############这样就改变了原始调用方法,原来都直接调用foo的,现在要调用show_time了,生产环境上忌讳这样做。
# import time
# def foo():
# print('foo....')
# time.sleep(2)
# def bar():
# print('bar....')
# time.sleep(3)
# def show_time(f):
# star_time = time.time()
# f()
# end_time = time.time()
# spend_time = end_time - star_time
# print(spend_time)
# show_time(foo)
###装饰器做法
import time
def show_time(f):
def inner():
star_time = time.time()
f()
end_time = time.time()
print('spend %s'%(end_time-star_time))
return inner @show_time #这个就是引用装饰器的标准写法,等同于foo = show_time(foo)
def foo():
print('foo.....')
time.sleep(2)
# foo = show_time(foo)
# foo() @show_time
def bar():
print('bar.....')
time.sleep(3)
# bar = show_time(bar)
# bar() foo()
bar()
############
装饰器的功能函数进行参数的定义,以及装饰器函数加参数来区分实现装饰器不同的功能调用。
def logger(flag): #定义装饰器函数
def show_time(f):
def inner(*x, **y):
star_time = time.time()
f(*x, **y)
end_time = time.time()
print('spend %s' % (end_time - star_time))
if flag == 'true': #设置条件,满足装饰器函数时会实现某个功能
print("logger is print")
return inner
return show_time
@logger('asdad') #调用装饰器函数时,参数不满足内里设置的条件,那么只调用装饰器里 计算程序运行的时间。
def foo():
print('foo.....')
time.sleep(2)
# foo = show_time(foo)
# foo() @logger('asdad') #调用装饰器函数时,参数不满足内里设置的条件,那么只调用装饰器里 计算程序运行的时间。
def bar():
print('bar.....')
time.sleep(3)
# bar = show_time(bar)
# bar() @logger('true') #调用装饰器函数时,参数满足内里设置的条件,那么不光调用装饰器里 计算程序运行的时间功能,还调用日志打印的功能。
def add(*a,**b):
sum = 0
for i in a:
sum += i
print(sum)
time.sleep(4) foo()
bar()
add(1,2,3,4,5)