组合与继承
1、组合是使用其他的类实例作为自己的一个属性(Has-a关系);
class DogInfo():
def __init__(self, name, age):
self.name = name
self.age = age
def p_info(self):
print("name is {}, age is {}.".format(self.name, self.age))
class Dog():
def __init__(self, name, age):
self.info = DogInfo(name, age) # has a DogInfo
def change_name(self, name):
self.info.name = name
def p_info(self):
self.info.p_info()
dog = Dog("dido", 4)
dog.change_name("Tom")
dog.p_info()
# 运行结果
name is Tom, age is 4.
2、子类继承父类的属性和方法(Is a 关系);
(1) 子类不重写父类的构造方法(__init__)和方法,实例化子类时,会自动调用父类定义的__init__和方法。
# 子类不重写父类的构造方法(__init__)和方法,实例化子类时,会自动调用父类定义的__init__和方法
class Father():
def __init__(self, name):
self.name = name
print("name: %s" % self.name)
def getName(self):
return "Father: " + self.name
class Son(Father):
pass
if __name__ == "__main__":
son = Son("麻花")
print(son.getName())
# 运行结果:
name: 麻花
Father: 麻花
(2) 重写父类的构造方法(__init__)和方法,实例化子类时,就不会调用父类已定义好的__init__和方法。
# 重写父类的构造方法(__init__)和方法,实例化子类时,就不会调用父类已定义好的__init__和方法
class Father():
def __init__(self, name):
self.name = name
print("name: %s" % self.name)
def getName(self):
return "Father: " + self.name
class Son(Father):
def __init__(self, name):
print("hello")
self.name = name
def getName(self):
return "Son: " + self.name
if __name__ == "__main__":
son = Son("麻花")
print(son.getName())
# 运行结果:
hello
Son: 麻花
(3) 如果重写了父类的构造方法(__init__)和方法,要继承父类的构造方法__init__和方法,可以使用 super 关键字。
# 如果重写了父类的构造方法(__init__)和方法,要继承父类的构造方法__init__和方法,可以使用 super 关键字
class Father():
def __init__(self, name):
self.name = name
print("name: %s" % self.name)
def getName(self):
return "Father: " + self.name
class Son(Father):
def __init__(self, name):
print("hello")
# super(Son, self).__init__(name)
Father.__init__(self, name)
def getName(self):
# return super(Son, self).getName()
return Father.getName(self)
if __name__ == "__main__":
son = Son("麻花")
print(son.getName())
# 运行结果:
hello
name: 麻花
Father: 麻花
3、优先使用组合保持代码简单。