闭包
叫什么闭包
有什么用:在执行函数的时候可以在外部函数中保留参数在内存中
写法:两个函数的嵌套,外部函数返回内部函数的引用,外部函数必须有参数
def 外部函数(参数):
def 内部函数():
pass
return 内部函数
nonlocal这个就是修改外部参数的值
装饰器
1. 先写一个万能装饰器
def set_fun(func):
def call_fun(*args,**kwargs):
return func(*args,**kwargs)
return call_fun
2. 在要装饰的函数上写一个@xxx
@set_fun
def test():
print("test")
装饰器内存分析图
装饰器有结论
装饰前的test函数是由func指向的
装饰后的test其实就是call_fun
道德上装饰不会去更改原先函数的返回值及调用方式
func,装饰前的test,call_fun三个参数必须一致
两个装饰器装饰一个函数
多个装饰器装饰一个函数的内存分析法:
能够说出执行的结果,秋裤大法跟电梯
装饰器传参
三个函数的嵌套,第三层函数返回闭包的外层的引用,第三层必须有参数
def set_args(args);
def set_fun(func):
def call_fun(*args,**kwargs):
return func(*args,**kwargs)
return call_fun
return set_fun
@set_args("xxx")
def test():
printl("xxxxxx")
装饰器实现场景使用
- 计算函数执行的时间,用来优化的
import time
num = 0
def set_fun(func):
def call_fun():
print(time.time())
func()
print(time.time())
return call_fun
@set_fun
def test():
print("print is data")
time.sleep(0.1)
test()
test()
test()
运行结果:
/usr/bin/python3.5 /home/python/Desktop/python就业/day17_装饰器/14-某函数的执行时间.py
1526045526.6764035
print is data
1526045526.7766392
1526045526.776716
print is data
1526045526.8769634
1526045526.8770266
print is data
1526045526.977325
2.统计方法被调多少次
import time
num = 0
def set_fun(func):
def call_fun():
global num
num += 1
print("time is %s" %num)
func()
return call_fun
@set_fun
def test():
print("print is num")
test()
test()
test()
test()
运行结果:
/usr/bin/python3.5 /home/python/Desktop/python就业/day17_装饰器/15-某函数的执行次数.py
time is 1
print is num
time is 2
print is num
time is 3
print is num
time is 4
print is num
Process finished with exit code 0