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
原文地址:https://www.cnblogs.com/CK85/p/10292630.html
时间: 2024-10-11 10:49:11