细说python类1——经典类和新式类

本文深入解析Python中的新式类与经典类的特性,通过实例代码演示了它们在继承、构造函数调用及类层次结构中的行为差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

python中的类分为新式类和经典类,具体有什么区别呢?简单的说,

1.新式类都从object继承,经典类不需要。

2.经典类继承深度优先,经典类继承广度优先。

3.新式类相同父类只执行一次构造函数,经典类重复执行多次。

下面举个例子说明一下。有类A、B、C、D、E,B、C继承A,D继承B、C,E继承D、A。先从经典类说起,代码如下:

class A:

  def __init__(self):
    print 'a',
class B(A):
  def __init__(self):
    A().__init__()
    print 'b',
class C(A):
  def __init__(self):
    A().__init__()
    print 'c',
class D(B,C):
  def __init__(self):
    B().__init__()
    C().__init__()
    print 'd',

class E(D,A):
  def __init__(self):
    D().__init__()
    A().__init__()
    print  'e',
d=D()
print ''
e=E()

代码执行后打印如下:

a a b a a b a a c a a c d 
a a b a a b a a c a a c d a a b a a b a a c a a c d a a e

第一行应该按如下分组a a b 、a a b |a a c 、a a c| d。首先执行D的init函数,D的init包含B和C的init,都执行之后才会执行print d,至于为什么显示执行了两次构造函数,这个取决于类内部的call方法,之后介绍。

class A(object):
  def __init__(self):
    print 'a',
class B(A):
  def __init__(self):
    super(B,self).__init__()
    print 'b',
class C(A):
  def __init__(self):
    super(C,self).__init__()
    print 'c',
class D(B,C):
  def __init__(self):
    super(D,self).__init__()
    print 'd',
class E(D,A):
  def __init__(self):
    super(E,self).__init__()
    print  'e',
d=D()
print ''
e=E()

结果打印如下:

a c b d 
a c b d e

可能有人会问,假如在子类里面不执行父类的init函数,不就不需要这么多次调用了么?但是,如果不执行父类init,怎么调用父类属性呢?

最后介绍一下 __bases__属性,可以查看类上一层的父类是什么。

执行print E.__bases__

打印(<class __main__.D at 0x7f1c1378e650>, <class __main__.A at 0x7f1c1378e950>)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值