实例属性和实例方法的存储方式
从两个问题出发:
1、为什么super.func(), 可以得到同名的父类方法,但是却没有super.val获得同名实例属性这种东西?
2、父类调用子类属性这种奇怪的东西为什么是可行的?
从obj = ClassA()开始,调用new返回一个实例,这相当于开辟了空间,接着init方法初始化各个变量,附属到obj中,如果init中调用了父类init,那么通常要让父类init先于子类初始化,否则同名的属性将会被覆盖。
因为属性需要开辟新的存储空间,每创建一个实例,就会开辟一块新的空间,所以不能存在同名的实例属性,因为会被覆盖无法找回。所以super.val是没有价值的。
但是类的方法代码是只有一份的,有专门的存储区,即使有多个实例他们的方法地址都是一样的,不同的是传入的参数self不同。这也是为什么可以ClassA.func(self)这种硬调用的原因。
再看父类调用子类属性,这是由于python是动态的,直到执行时才知道属性是否存在,也就是没有检查。按照上面所说的,由于python实际是将实例作为一个参数,传给实例方法,那么父类中调用子类属性当然也是顺理成章的(虽然这种方式很不科学)。
class Base:
def