商城首页欢迎来到中国正版软件门户

您的位置:首页 >Python __init__ 与 __new__ 区别解析

Python __init__ 与 __new__ 区别解析

  发布于2026-03-17 阅读(0)

扫一扫,手机访问

__new__负责创建对象,__init__负责初始化对象;前者是静态方法,返回实例,后者是实例方法,设置属性。__new__在__init__前执行,且仅当其返回本类实例时才调用__init__。

Python __init__与__new__区别_对象创建流程

Python 中 __new__ 负责创建对象,__init__ 负责初始化对象——这是最核心的区别。两者在对象生命周期中分工明确,缺一不可,但绝大多数场景只需关注 __init__;只有涉及自定义对象生成逻辑(如单例、不可变类型、ORM 实例化等)时,才需重写 __new__

__new__:真正“造出”对象的那一步

__new__ 是一个静态方法,由 Python 解释器在实例化前自动调用,它的任务是返回一个新创建的实例(通常是当前类的实例)。它接收的第一个参数是 cls(类本身),而不是 self(因为此时对象还没诞生)。

  • 必须有返回值,且通常应返回 super().__new__(cls) 或其他合法对象;若返回非本类实例,__init__ 将不会被调用
  • __init__ 之前执行,且只在显式调用类(如 A())时触发
  • 常用于控制实例创建过程,比如限制类只能有一个实例(单例模式)

__init__:给刚出生的对象“赋初值”

__init__ 是实例方法,在 __new__ 返回实例后立即被调用,作用是对该实例设置初始状态(如属性赋值)。它不负责生成对象,也不需要返回值(返回非 None 会触发 TypeError)。

  • 第一个参数是 self(即 __new__ 刚创建出来的那个对象)
  • 适合做常规初始化:如 self.name = nameself._cache = {}
  • 如果 __new__ 返回的是其他类的实例(例如父类或完全无关的类),那么调用的是那个类的 __init__,而非当前类的

对象创建的完整流程(以 A() 为例)

当你写 a = A(),Python 内部按如下顺序执行:

  • 调用 A.__new__(A) → 创建一个空的 A 实例(记为 obj
  • 检查 __new__ 的返回值是否为 A 的实例 → 若是,则继续;否则跳过 A.__init__
  • 调用 A.__init__(obj) → 对 obj 进行初始化
  • obj 绑定给变量 a

常见误区与实用建议

初学者容易混淆二者职责,导致逻辑错位。记住几个关键点:

  • 不要在 __new__ 中设置实例属性(如 self.x = 1),因为此时 self 还不存在(__new__ 没有 self 参数)
  • 若重写了 __new__ 却忘了调用 super().__new__(cls),又没手动构造对象,会导致 TypeError: __new__() should return an instance
  • 对于不可变类型(如 strint 子类),必须用 __new__ 修改创建逻辑,因为 __init__ 无法修改已创建的不可变对象
  • 日常开发中,95% 的类只需实现 __init__;把 __new__ 留给元编程、框架底层或特殊设计需求

理解这两者的协作关系,就掌握了 Python 对象诞生的关键机制。不复杂但容易忽略细节。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注