装饰器

装饰器原理剖析

装饰器的作用:在完全不改变函数的前提下,通过装饰的该函数的方法下实现在该函数的前面或者后面新增语句

装饰器的原理:

1、将被装饰的函数当做参数传递给你装饰器函数

2、将装饰器函数的返回值赋值给装饰器函数

装饰器1:仅仅实现最基本的功能

def outer(func):
    def inner():
        print("before")
        func()
        print("after")
    return inner
 
@outer
def f1():
    print("Hi,Everybody.")
 
f1()

上面就是最基本的装饰器的函数,outer函数为装饰器,f1为被装饰的函数;outer装饰函数f1,此时outer中的参数为args,此时args就是f1函数的内存地址,inner函数的内存地址就现在的,此时执行f1函数就是执行inner函数,而inner函数中就可以在旧的f1函数前后增加代码

装饰器2:处理被装饰的函数的返回值

如果原函数有返回值,怎么办呢?其实也很简单,因为上在上面的例子中,func就是被装饰的函数,也就是f1

def outer(func):
    def inner():
        print("before")
        ret = func()
        print("after")
        return ret
    return inner
 
@outer
def f1():
    print("Hi,Everybody.")
    return "这个是被装饰的函数的返回值"
 
ret = f1()
print(ret)

装饰器3:处理被装饰器的函数的参数

如果原函数有参数,该怎么办,其实这个也很简单,直接用万能参数即可

def outer(func):
    def inner(*args,**kwargs):
        print("before")
        ret = func(*args,**kwargs)
        print("after")
        return ret
    return inner
 
@outer
def f1(a):
    print(a)
    return "这个是被装饰的函数1的返回值"
 
 
@outer
def f2(a,b):
    print(a)
    print(b)
    return "这个是被装饰的函数2的返回值"
ret = f1("这个是被装饰的函数1的参数")
print(ret)
 
ret = f2("这个是被装饰的函数2的参数1","这个是被装饰的函数2的参数2")
print(ret)

解决查看函数信息的方法失效的问题

from functools import wraps

def deco(func):
    @wraps(func) #加在最内层函数正上方
    def wrapper(*args,**kwargs):
        return func(*args,**kwargs)
    return wrapper

@deco
def index():
    '''哈哈哈哈'''
    print('from index')

print(index.__doc__)
print(index.__name__)

 

posted @ 2018-10-14 22:33  小黑_9527  阅读(146)  评论(0编辑  收藏  举报