闭包,也叫词法闭包:如下所示函数A主要是为了函数B提供运行环境的
闭包只是在表现和形式上像函数,其实闭包并不是函数
由函数在嵌套环境中,内层函数里,对外层函数作用域的变量进行了引用,那么在外层函数返回后,内层函数依然可是使用外层函数的变量,这样的变量就构成了可以使用时的环境
所以闭包对于隐藏状态,以及在函数和作用域中进行切换,一个函数可以发挥很多种功能
#闭包:如下所示我们只需要不断的变化f调用变化就可以是函数B跟着变化了
def A(num1,num2):
    def B(x,y):
        print("我是%s!"%(num1+x))
        print("我是%s!"%(num2+y))
    return B
f=A(1,2)
f(3,4)


装饰器:

一下面的例子为例,如果我们有一个简单的函数C,我们在不动其他函数的基础上需要给函数C增加新的功能,需要怎么做呢?这就需要用到装饰器了


#这是不用装饰器时:
def A(func):
    def B():
        print("我是附加功能1!") #附加功能
        func()
        print("我是附加功能2!")  # 附加功能
    return B

def C():
    print("我是函数原来的功能!")
res=A(C)
res()
#用装饰器时:
def A(func):
    def B():
        print("我是附加功能1!") #附加功能
        func()
        print("我是附加功能2!") #附加功能
    return B
@A
def C():
    print("我是函数原来的功能!")
C()
#带参数的装饰器:
def A(func):
    def B(x):
        print("我是附加功能1!") #附加功能
        func(x)
        print("我是附加功能2!") #附加功能
    return B
@A
def C(x):
    print("我是函数原来的功能!%s"%x)
C('hello action!')

这里的@A也就等于了
res = A(C)

def A(canshu):
    def B(fun):
        def C(x):
            fun(x)
            print(canshu)
        return C
    return B
@A('hello')

def D(x):
    print(x)
D('你好!')

被装饰的函数的参数都需要传到返回函数的那一层去,必须我在C那一层调用被装饰的函数,就需要把参数传到C那一层!