更详细的装饰器,真心实力推荐,里面介绍的很清楚,介绍可见链接:https://blog.csdn.net/buster_zr/article/details/81104551
1、装饰器的理论:
(1)装饰器实际上就是一个函数
(2)有2个特别之处,参数是一个函数。返回值是一个参数
2、装饰器的简单理解:
实际上就是为了给一个程序添加功能,但是该程序已经上线或者已被使用,那么就不能大批量的修改源码,这样不现实,因此就产生了装饰器。
注意点:
(1)不能修改被装饰的函数的源代码
(2)不能修改被装饰的函数的调用方式
3、装饰器的组成方式:
函数+实参高阶函数+返回值高阶函数+嵌套函数+语法糖 = 装饰器
有关高阶函数的理解:
(1)把一个函数名当作实参传给另外一个函数(”实参高阶函数“)
(2)返回值中包含函数名(”返回值高阶函数“)
嵌套函数的理解:
嵌套函数指的是在函数内部定义一个函数,而不是调用。
语法糖:
写法:@xx ,一般写在函数的上方
4、真正装饰器的开始之处:
装饰器在装饰时,需要在每个函数前面加上@xxx
(1) 装饰无参函数,示例代码如下:
#装饰器装饰的函数无参数 def timer(func): #func其实指的就是test def deco(): start = time.time() func() #这里其实是对test的调用 stop = time.time() print (stop-start) return deco @timer #test函数使用装饰器 def test(): time.sleep(2) print ("test is running") test() 打印结果: test is running 2.003510952
(2)装饰有参函数,示例代码如下:
#装饰器装饰的函数有参数 def timer(func): def deco(*args,**kwargs): #添加可变参数*args和**kwargs start = time.time() func(*args,**kwargs) #这里也是一样,添加可变参数*args和**kwargs stop = time.time() print (stop-start) return deco @timer def test(value): #test函数有个参数value,正因为装饰器timer装饰的函数test有参数value,因此在timer中的有了可变参数 time.sleep(2) print ("test is running %s" %value) test("22") 打印结果: test is running 22
2.00424408913
3、带参数的装饰器,示例代码如下:
#装饰器带参数 def timer(parameter): def out_wapper(func): def wapper(*wargs,**kwargs): if parameter == "task1": start = time.time() func(*wargs,**kwargs) stop = time.time() print ("the task1 is run:",stop-start) elif parameter == "task2": func(*wargs, **kwargs) print ("the task2 is run:") return wapper return out_wapper @timer(parameter = "task1") def task1(): time.sleep(2) print "in the task1" @timer(parameter = "task2") def task2(): time.sleep(2) print "in the task2" task1() task2()
打印结果:
in the task1
('the task1 is run:', 2.002906084060669)
in the task2
the task2 is run: