python类的继承与多态

本文通过一个简单的Python示例,介绍了面向对象编程中多态的概念。通过继承Animal类创建不同的子类,并实现各自的run方法,展示了多态如何使得函数可以接受不同类型的对象并调用其相应的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

定义一个类

class Animal(object):
    def run(self):
        print 'Animal is runnning'

继承此类

class dog(Animal):
    pass

实例化

dog = dog()
dog.run()
**Animal is runnning**

以上:母类拥有一个方法
此方法会继承到子类,故子类也可以运行此方法(run())

如果给子类赋予方法

class dog(Animal):
    def run(self):
        print 'dog is runnning'
dog = dog()
dog.run()
**dog is runnning**

子类的run()覆盖了父类的run(),在代码运行的时候,总是会调用子类的run()。这样,我们就获得了继承的另一个好处:多态

要理解多态的好处,我们还需要再编写一个函数,这个函数接受一个Animal类型的变量:

def run_twice(animal):
  animal.run()
  animal.run()

当我们传入Animal的实例时,run_twice()就打印出:

run_twice(Animal())
Animal is running…
Animal is running…
当我们传入Dog的实例时,run_twice()就打印出:

run_twice(Dog())
Dog is running…
Dog is running…
当我们传入Cat的实例时,run_twice()就打印出:

run_twice(Cat())
Cat is running…
Cat is running…
看上去没啥意思,但是仔细想想,现在,如果我们再定义一个Tortoise类型,也从Animal派生:

class Tortoise(Animal):
  def run(self):
    print 'Tortoise is running slowly...'

当我们调用run_twice()时,传入Tortoise的实例:

run_twice(Tortoise())
Tortoise is running slowly…
Tortoise is running slowly…
你会发现,新增一个Animal的子类,不必对run_twice()做任何修改,实际上,任何依赖Animal作为参数的函数或者方法都可以不加修改地正常运行,原因就在于多态。
多态的好处就是,当我们需要传入Dog、Cat、Tortoise……时,我们只需要接收Animal类型就可以了,因为Dog、Cat、Tortoise……都是Animal类型,然后,按照Animal类型进行操作即可。由于Animal类型有run()方法,因此,传入的任意类型,只要是Animal类或者子类,就会自动调用实际类型的run()方法,这就是多态的意思:
对于一个变量,我们只需要知道它是Animal类型,无需确切地知道它的子类型,就可以放心地调用run()方法,而具体调用的run()方法是作用在Animal、Dog、Cat还是Tortoise对象上,由运行时该对象的确切类型决定,这就是多态真正的威力:调用方只管调用,不管细节,而当我们新增一种Animal的子类时,只要确保run()方法编写正确,不用管原来的代码是如何调用的。这就是著名的“开闭”原则:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值