0

0

Python装饰器深入教程_函数包装与复用技巧解析

冷漠man

冷漠man

发布时间:2026-01-02 18:28:03

|

753人浏览过

|

来源于php中文网

原创

装饰器本质是接收函数并返回新函数的高阶函数,核心为三步:接收原函数、定义包装逻辑、返回替代函数;支持带参配置、元信息保留及类实现状态管理。

python装饰器深入教程_函数包装与复用技巧解析

装饰器本质:函数的函数

装饰器不是语法糖,而是接收函数作为参数、返回新函数的高阶函数。它的核心逻辑就三步:接收原函数、定义包装逻辑、返回替代函数。写一个最简装饰器,不需要@符号也能理解:

  • def log_call(func): # 接收函数
  •   def wrapper(*args, **kwargs): # 定义包装行为
  •     print(f"Calling {func.__name__}")
  •     return func(*args, **kwargs)
  •   return wrapper # 返回新函数
  • def greet(name): return f"Hello, {name}"
  • greet = log_call(greet) # 手动包装 —— 这就是@log_call的等价操作

带参数的装饰器:多一层闭包

当你想让装饰器接受配置(比如日志级别、重试次数),就得再套一层函数。关键点在于:最外层接收装饰器参数,中间层接收被装饰函数,最内层执行逻辑。

  • def retry(times=3): # 装饰器工厂:接收配置
  •   def decorator(func): # 真正的装饰器:接收函数
  •     def wrapper(*args, **kwargs):
  •       for i in range(times):
  •         try:
  •           return func(*args, **kwargs)
  •         except Exception as e:
  •           if i == times - 1: raise
  •       return wrapper
  •   return decorator
  • @retry(times=2) # 使用时传参,实际调用的是 retry(2)(func)

保留原函数元信息:别让wrapper“冒名顶替”

直接写wrapper会丢失func.__name__func.__doc__等信息,调试和IDE提示会出问题。用functools.wraps是最稳妥解法。

PathFinder
PathFinder

AI驱动的销售漏斗分析工具

下载
  • 在wrapper定义后立即加 @functools.wraps(func)
  • 它会自动复制__name____doc____module____annotations__等属性
  • 不加wraps时help(greet)显示的是wrapper的帮助,加了才显示原函数文档
  • 自定义装饰器若需传递额外属性(如func._cached = True),仍要手动设置,wraps不处理这类自定义属性

类装饰器:用__call__管理状态

当需要在多次调用间维持状态(如计数、缓存、连接池),类比函数装饰器更清晰。核心是实现__init__(存配置)和__call__(执行包装逻辑)。

立即学习Python免费学习笔记(深入)”;

  • class CountCalls:
  •   def __init__(self):
  •     self.count = 0
  •   def __call__(self, func):
  •     def wrapper(*args, **kwargs):
  •       self.count += 1
  •       print(f"{func.__name__} called {self.count} times")
  •       return func(*args, **kwargs)
  •     return wrapper
  • @CountCalls() # 注意括号:必须实例化才能用
  • 类装饰器天然支持实例属性共享,适合有状态场景;无状态时函数装饰器更轻量

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

891

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

32

2025.12.06

go语言闭包相关教程大全
go语言闭包相关教程大全

本专题整合了go语言闭包相关数据,阅读专题下面的文章了解更多相关内容。

152

2025.07.29

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

136

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号