python语法_装饰器

装饰器的知识点储备:

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)
posted @ 2018-12-03 16:47  小水胖  阅读(162)  评论(0编辑  收藏  举报