Python 的子类也会继承得到父类的构造方法,但如果子类有多个直接父类,那么会优先选择排在最前面的父类的构造方法。例如如下代码:
class Employee :
def __init__ (self, salary):
self.salary = salary
def work (self):
print('普通员工正在写代码,工资是:', self.salary)
class Customer:
def __init__ (self, favorite, address):
self.favorite = favorite
self.address = address
def info (self):
print('我是一个顾客,我的爱好是: %s,地址是%s' % (self.favorite, self.address))
# Manager继承了Employee、Customer
class Manager (Employee, Customer):
pass
m = Manager(25000)
m.work() #①
#m.info() #②上面程序中第 13 行代码定义了 Manager 类,该类继承了 Employee 和 Customer 两个父类。接下来程序中的 Manager 类将会优先使用 Employee 类的构造方法(因为它排在前面),所以程序使用 Manager(25000)来创建 Manager 对象。该构造方法只会初始化 salary 实例变量,因此执行上面程序中 ① 号代码是没有任何问题的。
但是当执行到 ② 号代码时就会引发错误,这是由于程序在使用 E