1:继承,顾名思义就是子代继承父辈的一些东西,在程序中也就是子类继承父类的属性和方法。
1 #Author : Kelvin 2 #Date : 2019/1/16 18:57 3 4 class Father: 5 money=1000 6 7 def __init__(self,name): 8 print("父类的init方法...") 9 self.name=name 10 11 def teach(self): 12 print("%s 正在教儿子学习..."%self.name) 13 14 class Son(Father): 15 pass 16 17 18 s=Son("kelvin") 19 print(s) 20 #>>>: 父类的init方法... 21 #>>>: <__main__.Son object at 0x0000018B1A1AEEB8> 22 s.teach() 23 # >>>: kelvin 正在教儿子学习...
可见,即使Son类没有定义init方法,money属性和teach方法,但是由于Son类继承了Father类,所以在实例化Son时可以使用父类的属性值和方法。
误区:如果子类存在与父类同名的属性和方法,并不是覆盖了从父类继承的属性。因为子类会先从本类开始找对应方法,如果没有再去父类调用。
归一化设计(接口继承):
使用继承的最大作用就是定义一种规范。让继承者按照规范进行书写代码。
第一种:普通类继承。缺点:不能限制子类根据父类的规范定义函数。
1 #Author : Kelvin 2 #Date : 2019/1/16 19:53 3 4 class Basic(): 5 6 def eat(self): 7 pass 8 9 def drink(self): 10 pass 11 12 class People(Basic): 13 def __init__(self,name): 14 self.name=name 15 def eat(self): 16 print("%s吃饭"%self.name) 17 def drink(self): 18 print("%s喝水"%self.name) 19 20 class Cat(Basic): 21 def __init__(self,name): 22 self.name=name 23 def eat(self): 24 print("%s吃饭"%self.name) 25 26 c=Cat("猫咪") 27 c.eat() 28 c.drink()
很明显,代码可以执行,说明子类即使不按照父类定义的标准执行,也不会报错。很明显父类不能起到规定的作用。接下来可以使用这种实现:
1 #Author : Kelvin 2 #Date : 2019/1/16 19:53 3 import abc 4 class Basic(metaclass=abc.ABCMeta): 5 @abc.abstractmethod 6 def eat(self): 7 pass 8 @abc.abstractmethod 9 def drink(self): 10 pass 11 12 class People(Basic): 13 def __init__(self,name): 14 self.name=name 15 def eat(self): 16 print("%s吃饭"%self.name) 17 def drink(self): 18 print("%s喝水"%self.name) 19 20 class Cat(Basic): 21 def __init__(self,name): 22 self.name=name 23 def eat(self): 24 print("%s吃饭"%self.name) 25 26 c=Cat("猫咪") 27 c.eat() 28 c.drink()
此时,由于Cat类继承了Basic,但是由于Basic类做了限制,继承Basic类必须实现所有Basic中的方法,但是Cat中只实现了部分方法,因此程序报错。
如果在子类中定义了和父类同名的属性和成员方法时,如何才能调用父类属性和方法呢?
1 #Author : Kelvin 2 #Date : 2019/1/16 20:45 3 4 class way: 5 def __init__(self,name,speed): 6 self.name=name 7 self.speed=speed 8 def run(self): 9 print("所有交通工具!") 10 11 class subway(way): 12 def __init__(self,name,speed,line): 13 # way.__init__(self,name,speed) 14 # super(subway, self).__init__() 15 super().__init__(name,speed) 16 self.line=line 17 def run(self): 18 # way.run(self) 19 # super(subway, self).run() 20 super().run() 21 print("地铁交通工具!") 22 23 s=subway("徐州地铁","10km/min","13号线路") 24 s.run()
注释的两种方式可以实现相同效果!