装饰器、闭包

用到了老是忘记,还是记录一下吧,

装饰器、闭包

python的装饰器、闭包是进入Python高级语法的基础,使用装饰器之前,有以下条件:

  • 存在闭包
  • 存在需要被装饰的函数
  • 理解函数地址的概念
理解函数的地址值

众所周知,我们定义函数后,函数名加()可以调用函数,那么我们尝试调用一下函数名呢?

    def test():
        pass
    
    
    def test1():
        pass
    
    
    # 打印函数名
    print(test)

运行结果:

<function test at 0x00000294B0F7E280>

也就是说每个函数名字都存在着他的内存地址值

理解闭包

闭包可以理解成为定义在一个函数内部的函数

在一个函数中定义了一个函数,内部函数里运用了外函数的临时变量,并且外函数的返回值是内函数的引用(函数地址值),这样就构成了一个闭包

条件:

  • 存在函数的嵌套关系
  • 内层函数引用了外层函数的变量
  • 外层函数返回内层函数的地址值

话不多说,我们上代码:

# - 存在函数的嵌套关系
# - 内层函数引用了外层函数的变量
# - 外层函数返回内层函数的地址值


def out_func(num):
    def in_func(in_num):
        print("外部函数的变量", num)
        print("内部函数的变量", in_num)
    return in_func


print(out_func(10))
res = out_func(10)
res(5)

运行结果:

<function out_func.<locals>.in_func at 0x000001FBFFD31310>
外部函数的变量 10
内部函数的变量 5
装饰器

在不修改源代码的基础上,给函数增加新的功能

装饰器会将被装饰的函数当作参数传递给装饰器同名的函数

添加装饰器,需要:

  • 存在闭包
  • 存在需要被装饰的函数

例如我们想给一个函数增加一个“输入密码”的功能,在原则上我们是不会区修改原函数的代码内容的,那么怎么实现呢?我们可以使用装饰器,给函数添加功能。

def out_func(login):
    def in_func():
        print("密码输入完成")
        login()
    return in_func


@out_func
def login():
    print("登录成功")


login()

运行结果:

密码输入完成
登录成功

这样就在不修改原来函数的基础上增加了新的功能。

posted @ 2023-10-16 11:45  时光如你般美好  阅读(9)  评论(0编辑  收藏  举报