__new__ 总是先于__init__执行,负责分配内存并返回实例;__init__在实例存在后初始化属性。前者是静态方法,后者是实例方法,日常开发通常只需重写__init__。

在 Python 中,__new__ 总是先于 __init__ 执行,且只有当 __new__ 返回了当前类的实例时,__init__ 才会被调用。这不是“谁先写谁先运行”的问题,而是 Python 对象创建机制决定的底层顺序。
__new__ 是真正的构造器,负责分配内存并返回实例
__new__ 是一个静态方法(第一个参数是 cls),它的核心职责是:申请一块内存空间,构造出一个尚未初始化的对象,并返回它。它不操作对象的状态,也不设置属性——那是 __init__ 的事。
常见使用场景包括:
- 实现单例模式:控制只返回同一个实例
- 自定义不可变类型(如继承
str、tuple):因为它们不能在__init__中修改,必须在__new__中就定好值 - 根据参数动态决定返回哪个类的实例(比如工厂式构造)
__init__ 是初始化器,负责设置实例状态
__init__ 是一个实例方法(第一个参数是 self),它在对象已存在、内存已分配的前提下被调用,用于给这个现成的对象“赋初值”:设置属性、打开资源、触发逻辑等。
注意:__init__ 不返回任何值(隐式返回 None),也不能改变实例本身——它没有权力决定“这个对象要不要被创建”,那已经由 __new__ 决定了。
典型用途有:
- 为实例属性赋默认值或传入值
- 执行依赖实例的初始化逻辑(如连接数据库、注册回调)
- 校验参数合法性(但要注意:此时对象已存在,校验失败只能抛异常,不能阻止构造)
执行流程清晰可验证
你可以通过简单代码观察顺序:
class A:
def __new__(cls, *args, **kwargs):
print("__new__ called")
instance = super().__new__(cls)
return instance
def __init__(self, x):
print("__init__ called")
self.x = x
a = A(42)
输出一定是:
__new__ called __init__ called
如果 __new__ 没有返回本类实例(比如返回 int(1) 或另一个类的实例),那么 __init__ 根本不会被调用。
什么时候该动 __new__,什么时候只用 __init__?
绝大多数业务类,只需写 __init__ 就够了。__new__ 属于“元编程”范畴,介入的是对象诞生前一刻,不是日常开发需要触碰的层次。
判断是否需要重写 __new__,就看问题是否发生在“对象还没出生”的阶段:
- 要控制实例数量(单例、对象池)→ 改
__new__ - 要让类表现得像内置不可变类型 → 改
__new__ - 想根据参数返回子类实例(比如 JSON 解析后自动选
Dict还是List)→ 改__new__ - 只是想设置几个属性、打印日志、校验输入 → 只用
__init__










