Python day 8(2) 继承和多态

1
 在OOP程序设计中,当大家定义三个class的时候,可以从有些现有的class继承,新的class称为子类(Subclass),而被一而再的class称为基类、父类或超类(Base
class、Super
class)。比如,大家早已编制了2个名为Animal的class,有一个run()方式可以直接打印。

当大家须求编制DogCat类时,就可以直接从Animal类继承:

1 class Dog(Animal):
2     pass
3 
4 class Cat(Animal):
5     pass

对于Dog来说,Animal就是它的父类,对于Animal来说,Dog就是它的子类。Cat和Dog类似。

一连最大的补益是子类拿到了父类的满贯功效。由于Animial实现了run()方法,因此,DogCat作为它的子类,什么事也没干,就自行拥有了run()方法:

1 dog = Dog()
2 dog.run()
3 
4 cat = Cat()
5 cat.run()

2

1 class Dog(Animal):
2 
3     def run(self):
4         print('Dog is running...')
5 
6 class Cat(Animal):
7 
8     def run(self):
9         print('Cat is running...')

 

当子类和父类都存在相同的run()方法时,我们说,子类的run()覆盖了父类的run(),在代码运行的时候,总是会调用子类的run()。这样,我们就获得了继承的另一个好处:多态。
3  当我们定义一个class的时候,我们实际上就定义了一种数据类型。我们定义的数据类型和Python自带的数据类型,比如str、list、dict没什么两样。判断一个变量是否是某个类型可以用isinstance()判断。
4 在继承关系中,如果一个实例的数据类型是某个子类,那它的数据类型也可以被看做是父类。但是,反过来就不行。
5 鸭子类型:

     
对于静态语言(例如Java)来说,如果急需传入Animal品类,则传出的目标必须是Animal项目或然它的子类,否则,将不能调用run()方法。

     
对于Python那样的动态语言来说,则不肯定须求传入Animal品种。我们只要求确保传入的对象有一个run()主意就可以了:

1 class Timer(object):
2     def run(self):
3         print('Start...')

 

这就是动态语言的“鸭子类型”,它并不要求严格的继承体系,一个对象只要“看起来像鸭子,走起路来像鸭子”,那它就可以被看做是鸭子。

 

相关文章