python中新式类和经典类

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

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

  Python 2.x中默认都是经典类,只有显式继承了object才是新式类

  Python 3.x中默认都是新式类,不必显式的继承object

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

  在多重继承关系下,子类的实例对象想要调用父类的方法,向上寻找时的顺序。

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

  

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

上一篇:Http TCP/IP 协议的关系


下一篇:python中的类与继承