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

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 = name、self._cache = {} - 如果
__new__返回的是其他类的实例(例如父类或完全无关的类),那么调用的是那个类的__init__,而非当前类的
对象创建的完整流程(以 A() 为例)
当你写 a = A(),Python 内部按如下顺序执行:
立即学习“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 - 对于不可变类型(如
str、int子类),必须用__new__修改创建逻辑,因为__init__无法修改已创建的不可变对象 - 日常开发中,95% 的类只需实现
__init__;把__new__留给元编程、框架底层或特殊设计需求
理解这两者的协作关系,就掌握了 Python 对象诞生的关键机制。不复杂但容易忽略细节。










