我定义了以下三个类,Mother,Father,Son,Son继承了Mother,Father两个类
class Mother():
name = 'hanmeimei'
class Father():
name = 'lilei'
class Son(Mother,Father):
pass
然后创建Son的实例s
s = Son()
print(s.name)
输出结果为:
hanmeimei
当我给Father类添加init():
class Father():
# 添加的代码
def __init__(self):
self.name = 'liming'
输出结果为:
# 这里跟我设想的不一样,我原以为还是会打印hanmeimei
liming
自己尝试分析原因:
1.首先了解init()方法:它会在我们创建空对象之后调用,完成对空对象的初始化。
2.python中每个类都继承自Object类
3.在第一次运行中,我所写的三个类都没有显示调用init()方法,但是并意味着init()方法没有调用,而是系统会隐式调用init()方法完成对象的初始化。这个隐式调用的init()方法其实是藏在超类Object里面。即Object类有一个init()函数。
4.修改了Father类,给Father类添加了init()函数之后,结果打印的结果变成了liming,我的理解是涉及到类的继承:
- Son继承了Mother和Father两个父类,两个父类都有name的属性,那么Son的name属性继承于哪个父类是有规律的,python中的继承遵循‘从左至右,广度优先’的原则,定义的时候
class Son(Mother,Father):
Mother在前,那么就会先在Mother类中寻找是否有name属性。那么应该可以解释为什么打印的是‘ liming’了,因为Son本类中没有init()函数,所以会去父类中找,但是Mother类也没有,根据广度优先,就会找Father类,而不是去Object类寻找。
然后我又给Mother类添加了init():
class Mother():
def __init__(self):
self.name = 'hanmeimei'
print('mother')
执行结果果然是hanmeimei:
mother
hanmeimei
然后我又给Son类添加了init():
class Son(Mother,Father):
def __init__(self):
self.name = 'xiaoming'
print('son')
然后执行结果为:
xiaoming
son
从执行结果可以看出,init()方法只被调用了一次。