Python—面向对象小解(6)-闭包、装饰器

2024-06-03 10:28

本文主要是介绍Python—面向对象小解(6)-闭包、装饰器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、闭包

        在Python中,闭包(closure)是一个函数对象,即使在其词法作用域外被调用,它仍然能访问该作用域内的变量。闭包通过“捕获”周围作用域的变量,保持这些变量的状态,即使在外部函数已经返回之后,这些变量仍然可以被访问和修改。

        

闭包是指:

  • 一个嵌套函数。
  • 这个嵌套函数引用了它的外部函数中的自由变量。
  • 这个嵌套函数在其外部函数返回后,仍然可以访问这些自由变量。
# 局部变量的销毁问题def func():# 局部变量a = 10a = a+1print(a)func() # 函数调用结束后内部局部变量会自动销毁
func() # 第二次调用函数时,会重新定义局部变量,重新计算print('---------------------------')
# 使用闭包可以将局部变量保存下来,每次调用函数时,使用同一个局部变量操作
# 闭包的格式是函数的嵌套定义
def func1():# 定义局部变量a = 10def func2():# 内部声明局部变量nonlocal aa = a+1print(a)# 将内部定义的函数名返回return func2f2 = func1() # f2=func2
# 使用加法计算
f2()
f2()

相关概念:

  1. 嵌套函数(Nested Functions):在一个函数内部定义另一个函数。
  2. 自由变量(Free Variables):在闭包中使用的外部变量,这些变量并不是在闭包中定义的,但被闭包引用。
  3. 作用域(Scope):变量的可见范围。在Python中,通常有四种作用域:局部(Local)、嵌套(Enclosing)、全局(Global)和内建(Built-in),简称LEGB规则。

闭包的特性

闭包有以下几个重要特性:

  • 状态保持:闭包能够保持它创建时的状态。这意味着即使在外部函数的执行已经结束后,内部函数仍然可以访问其作用域内的变量。
  • 私有化变量:闭包常用于创建私有变量,因为这些变量只能通过闭包内部的函数进行访问和修改,外部无法直接访问。

闭包的实际应用

  1. 计数器
def make_counter():count = 0def counter():nonlocal countcount += 1return countreturn countercounter1 = make_counter()
print(counter1())  # 输出: 1
print(counter1())  # 输出: 2counter2 = make_counter()
print(counter2())  # 输出: 1
  1. 访问控制
def create_account(initial_balance):balance = initial_balancedef get_balance():return balancedef deposit(amount):nonlocal balancebalance += amountreturn balancereturn get_balance, depositget_balance, deposit = create_account(100)
print(get_balance())  # 输出: 100
print(deposit(50))    # 输出: 150
print(get_balance())  # 输出: 150

二、装饰器

        装饰器(Decorator)是Python中的一种设计模式,允许在不修改函数或方法定义的情况下,动态地给函数或方法增加功能。装饰器本质上是一个高阶函数(即接受函数作为参数或返回一个函数的函数),它返回一个新的函数,这个新函数通常对原函数进行了某种修改或扩展。

# 使用闭包定义装饰器
def func1(f):# 外部函数定义接受参数,参数的类型要求是其他函数# f需要接受其他函数,就是需要装饰修改逻辑的函数def func2():# 调用之前增加登录判断print('登录成功')# 调用需要修改执行的函数f()# 返回内部函数return func2# 支付功能已经编写完成,不能再随意修改,如果此时需要再支付中增加一个登录判断如何实现
def pay():print('支付')
# 调用装饰器
f2 = func1(pay) # f=pay  f2 = func2
f2()def order():print('下单')
  • 被装饰的函数数据返回

def login(f):"""登录装饰器:param f: 接收被装饰的函数:return:"""def inner(name, password):# 编写登录逻辑if name == '张三':if password == '123456':print('登录成功')# 登录成执行被装饰的函数# 可以给传递数据和接收返回值res= f(1000)print(res)else:print('密码错误')else:print('用户名错误')return innerdef pay(price):print('订单支付逻辑')print(f'支付金额{price}')return '支付成功'# 使用装饰器装饰支付函数
f = login(pay)
# f = inner
f('张三','123456')
  • 采用语法糖格式使用装饰器

    • 语法糖格式 @装饰器函数名

def login(f):"""登录装饰器:param f: 接收被装饰的函数:return:"""def inner(name, password,price):# 编写登录逻辑if name == '张三':if password == '123456':print('登录成功')# 登录成执行被装饰的函数res= f(price)print(res)else:print('密码错误')else:print('用户名错误')return inner# 使用语法糖
@login
def pay(price):print('订单支付逻辑')print(f'支付金额{price}')return '支付成功'# 调用被装饰的函数
# 此时pay函数变成了inneer函数
pay('张三','123456',1000)

这篇关于Python—面向对象小解(6)-闭包、装饰器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026727

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e