登录
首页 >  文章 >  python教程

Python 3 中不再需要显式继承 object 的原因,主要与 Python 3 对类的默认行为进行了统一和优化。在 Python 2 中,存在两种类:经典类(old-style class) 和 新式类(new-style class),而 Python 3 已经完全移除了经典类,所有类都自动成为新式类。为什么不再需要显式继承 object?在 Python 2 中,如果你定义一个类时没有显

时间:2026-05-26 10:57:34 445浏览 收藏

Python 3 彻底摒弃了 Python 2 中的经典类与新式类之分,所有通过 `class` 关键字定义的类——无论是否显式继承 `object`——都自动成为功能完备的新式类,享有 `super()`、C3 线性化 MRO、`__slots__`、`__getattribute__` 等现代特性;显式写 `class MyClass(object):` 在纯 Python 3 环境下纯属冗余,既不改变行为也不提升性能,仅存于部分项目中作为历史兼容或风格习惯,而真正驱动这些高级能力的,是解释器底层对所有类的统一新式类语义支持。

为什么在Python 3中不再需要显式继承object_理解新式类与经典类区别

Python 3 中所有类默认都是新式类,class Person:class Person(object): 完全等价,显式写 object 是冗余的,但不报错。

Python 3 中 class A: 就是新式类

Python 3 已彻底移除经典类。无论你写 class A:class A(): 还是 class A(object):,解释器都会自动让 A 继承 object,且 A.__bases__ 永远包含 object

验证方式:

>>> class A: pass
>>> A.__bases__
(<class 'object'>)
>>> type(A)
<class 'type'>
>>> isinstance(A(), A)
True

这说明:类本身是 type 的实例,实例的类型就是类本身(不是统一的 instance),这是新式类的核心特征。

super() 和 __mro__ 在 Python 3 中总是可用

只要用了 class 关键字定义的类,就支持 super() 调用和 __mro__ 属性——因为它们依赖新式类的 MRO(Method Resolution Order)机制。

  • super() 在经典类中会抛出 TypeError: must be type, not classobj,但在 Python 3 中永不触发
  • C.mro() 返回的是 C3 线性化结果,比如 class D(B, C): pass 的 MRO 顺序严格按 C3 算法计算,不是简单“广度优先”
  • 即使你漏掉 objectD.mro() 末尾也一定是 object

__new__、__getattribute__、__slots__ 等特性默认生效

这些功能只存在于新式类中。在 Python 3 中,哪怕你一个父类都不写,也能直接用:

  • __new__ 总是存在,且在 __init__ 之前被调用
  • __getattribute__ 替代了经典类中不稳定的 __getattr__ 查找逻辑
  • __slots__ 可以限制实例属性,且不会因“非新式类”而静默失效

例如:

>>> class S:
...     __slots__ = ['name']
>>> s = S()
>>> s.name = 'alice'
>>> s.age = 10  # AttributeError: 'S' object has no attribute 'age'

Python 2 的遗留写法在 Python 3 中只是“看起来多余”

很多项目仍保留 class A(object): 写法,主要出于两个现实原因:

  • 保持与 Python 2 兼容(如果代码还需跑在 2.7 上)
  • 团队风格统一,或作为显式信号:“这个类是完整的新式类语义”

但要注意:在纯 Python 3 环境下,它不带来任何行为差异,也不提升性能或安全性;反而可能误导新人以为 object 是“可选基类”。真正的关键点在于——MRO 行为、属性访问协议、实例类型这些底层机制,早已由解释器硬编码绑定到所有类上,和你写不写 object 无关。

理论要掌握,实操不能落!以上关于《Python 3 中不再需要显式继承 object 的原因,主要与 Python 3 对类的默认行为进行了统一和优化。在 Python 2 中,存在两种类:经典类(old-style class) 和 新式类(new-style class),而 Python 3 已经完全移除了经典类,所有类都自动成为新式类。为什么不再需要显式继承 object?在 Python 2 中,如果你定义一个类时没有显式继承 object,它就是一个经典类,而如果继承了 object,就是新式类。新式类支持一些高级特性,如:使用 super() 函数支持描述符(descriptors)更好的属性访问机制支持 __slots__支持 __init_subclass__ 等但在 Python 3 中,所有类都是新式类,无论是否显式继承 object。因此,即使你不写 class MyClass:,它也会自动继承 object,即等同于 class MyClass(object):。新式类 vs 经典类的区别特性新式类(Python 3)经典类(Python 2)默认继承自动继承 `》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>