装饰器的使用:
在不想修改函数的调用方式,但是想给函数添加内容的功能的时候使用
为什么使用装饰器:
软件实体应该是可扩展,而不可修改的。也就是说,对扩展是开放的,而对修改是封闭的。
因此,引出了开放封闭原则:
对扩展开放,意味着有新的需求或变化时,可以对现有代码进行扩展,以适应新的情况。
对修改封闭,意味着类一旦设计完成,就可以独立完成其工作,而不要对类进行任何修改。
所以函数在开发好之后就应该将其封闭,这样可以防止一些不必要的错误的发生
这时候想给原函数添加功能那么久用到了装饰器
装饰器的固定模式
1
2 3 4 5 6 |
# 装饰器的固定模式
def wrapper(func): def inner(*args, **kwargs): ret = func(*args, **kwargs) return ret return inner |
案例:
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
# -*- coding:utf-8 -*-
# 上面为一个正常的函数调用 # 但是假使我在不修改函数内容的前下给函数打印出函数的运行时间这这里就要使用到装饰器 import time def wrapper(func): def inner(*args, **kwargs): start_time = time.time() print('nihao') ret = func(*args, **kwargs) end_time = time.time() print(end_time-start_time) return ret return inner # 定义一个函数func2 @wrapper # 语法糖,给下面的函数做装饰 等于调用了func2 = wrapper(func2) def func2(a): print("hello") return a+1 ret = func2(2) # 这里的func2其实是指向了inner的地址,函数名称不变 print(ret) # 这里成功的在不改变调用函数的前提下完成了函数的修改 |
装饰器的本质就是在函数嵌套中调用被装饰的函数,用来增加函数的灵活性!