主要介绍类的继承
有以下代码
看运行结果
由此可以总结出
1)实例化C时,将C从头到尾扫一遍,创建C的类属性,遇到方法不执行,,只开辟内存放方法体,然后执行C的构造函数,
2)执行C构造函数时,遇到了B,就把B从头到尾扫一遍,创建B的类属性,开辟内存放B的方法,最后执行B的构造函数
3)执行B构造函数时,遇到A,同以上
然后A.__init__执行完毕并弹出栈,class A()执行完毕并弹出栈。
4)回到class B(),从上次未执行完的地方print(‘B的class’, self.class, name)继续执行。然后B.__init__执行完毕并弹出栈,class B()执行完毕并弹出栈。
5)回到class C(),从上次未执行完的地方print(‘C的class’)继续执行。然后C.__init__执行完毕并弹出栈,class C()执行完毕并弹出栈。程序运行完毕。
由于是对class C()进行实例化,上面的self都是指class C()的实例而不是class A()的或者class B()的。因此self.__class__清一色的显示<class ‘main.C’>而不是<class ‘main.A’>或<class ‘main.B’> 。
注意点:类属性和实例属性不一样
类属性在类中可以直接访问,实例属性必须先实例类