【Python】Python中装饰器和魔法方法的区别

在Python中,装饰器(Decorators)和魔法方法(Magic Methods)是两种不同的高级特性,分别服务于不同的目的。

装饰器 (Decorators)

装饰器是一种强大的工具,它可以修改或增强函数、方法或类的行为。装饰器本质上是一个接收函数作为输入并返回新函数的可调用对象。在Python中,装饰器通常使用 @decorator_name 的语法糖形式出现在函数定义之前。装饰器使得开发者能够在不改变原有函数源代码的情况下,通过包装(wrapping)原始函数来增加额外的功能,比如日志记录、性能分析、权限校验等。

例如:

python 复制代码
def log_decorator(func):
    def wrapper(*args, **kwargs):
        print(f"Calling function {func.__name__}")
        result = func(*args, **kwargs)
        print(f"Function {func.__name__} returned {result}")
        return result
    return wrapper

@log_decorator
def add(a, b):
    return a + b

在这个例子中,log_decorator 是一个装饰器,它会在调用 add 函数前后打印日志信息。

魔法方法 (Magic Methods / Dunder Methods)

魔法方法是在Python类中定义的一些特殊方法,它们以两个下划线开始和结束,例如 __init__, __str__, __add__, __len__ 等。这些方法在特定场景下会被Python解释器自动调用,用来实现面向对象编程中的许多核心特性,如对象初始化、字符串表示、运算符重载、迭代、上下文管理等。

例如:

  • __init__(self, ...):当创建一个类的新实例时自动调用,常用于初始化对象的状态。
  • __str__(self):定义对象转换为字符串时的行为,当使用 print() 或者 str() 函数时触发。
  • __add__(self, other):重载加法操作符,允许类实例之间进行加法运算。
python 复制代码
class MyInt:
    def __init__(self, value):
        self.value = value

    def __add__(self, other):
        return MyInt(self.value + other.value)

    def __str__(self):
        return f"MyInt({self.value})"

a = MyInt(5)
b = MyInt(3)
print(a + b)  # 自动调用 __add__ 方法
print(a)      # 自动调用 __str__ 方法

在这个例子中,MyInt 类定义了 __init__ 初始化方法、__add__ 用于支持加法操作的魔法方法和__str__用于显示字符串表示的魔法方法。

相关推荐
Mark_Aussie18 分钟前
Flask-SQLAlchemy使用小结
python·flask
程序员阿龙31 分钟前
【精选】计算机毕业设计Python Flask海口天气数据分析可视化系统 气象数据采集处理 天气趋势图表展示 数据可视化平台源码+论文+PPT+讲解
python·flask·课程设计·数据可视化系统·天气数据分析·海口气象数据·pandas 数据处理
ZHOU_WUYI36 分钟前
Flask与Celery 项目应用(shared_task使用)
后端·python·flask
黑客老李1 小时前
JavaSec | SpringAOP 链学习分析
java·运维·服务器·开发语言·学习·apache·memcached
开开心心就好1 小时前
高效Excel合并拆分软件
开发语言·javascript·c#·ocr·排序算法·excel·最小二乘法
且慢.5891 小时前
Python_day47
python·深度学习·计算机视觉
特立独行的猫a1 小时前
Nuxt.js 中的路由配置详解
开发语言·前端·javascript·路由·nuxt·nuxtjs
佩奇的技术笔记1 小时前
Python入门手册:异常处理
python
勤奋的知更鸟1 小时前
Java编程之原型模式
java·开发语言·原型模式
大写-凌祁1 小时前
论文阅读:HySCDG生成式数据处理流程
论文阅读·人工智能·笔记·python·机器学习