一文带你了解python中的多态

一文带你了解python中的多态

我们都知道,python是弱类型语言,其最明显的特征是在使用变量时,无需为其指定具体的数据类型。这会导致一种情况,即同一变量

可能会被先后赋值不同的类对象,例如:

classCLanguage:
defsay(self):
print("赋值的是CLanguage类的实例对象")
classCpython:
defsay(self):
print("赋值的是Cpython类的实例对象")
a=CLanguage()
a.say()
a=Cpython()
a.say()

运行结果为:

赋值的是CLanguage类的实例对象
赋值的是Cpython类的实例对象

可以看到,a 可以被先后赋值为 CLanguage 类和 Cpython 类的对象,但这并不是多态。类的多态特性,还要满足以下 2 个前提条件:继承:多态一定是发生在子类和父类之间;重写:子类重写了父类的方法。

下面程序是对上面代码的改写:

classCLanguage:
defsay(self):
print("调用的是Clanguage类的say方法")
classCpython(CLanguage):
defsay(self):
print("调用的是Cpython类的say方法")
classCLinux(CLanguage):
defsay(self):
print("调用的是CLinux类的say方法")
a=CLanguage()
a.say()
a=Cpython()
a.say()
a=CLinux()
a.say()

执行结果

调用的是Clanguage类的say方法
调用的是Cpython类的say方法
调用的是CLinux类的say方法

可以看到,Cpython 和 CLinux 都继承自 CLanguage 类,且各自都重写了父类的 say() 方法。从运行结果可以看出,同一变量 a 在执行同一个 say() 方法时,由于 a 实际表示不同的类实例对象,因此 a.say() 调用的并不是同一个类中的 say() 方法,这就是多态。

但是,仅仅学到这里,读者还无法领略 python 类使用多态特性的精髓。其实,python 在多态的基础上,衍生出了一种更灵活的编程机制。

继续对上面的程序进行改写:

classWhoSay:
defsay(self,who):
who.say()
classCLanguage:
defsay(self):
print("调用的是Clanguage类的say方法")
classCpython(CLanguage):
defsay(self):
print("调用的是Cpython类的say方法")
classCLinux(CLanguage):
defsay(self):
print("调用的是CLinux类的say方法")
a=WhoSay()
#调用CLanguage类的say()方法
a.say(CLanguage())
#调用Cpython类的say()方法
a.say(Cpython())
#调用CLinux类的say()方法
a.say(CLinux())

程序执行结果为:

调用的是Clanguage类的say方法
调用的是Cpython类的say方法
调用的是CLinux类的say方法

此程序中,通过给 WhoSay 类中的 say() 函数添加一个 who 参数,其内部利用传入的 who 调用 say() 方法。这意味着,当调用