我们都知道,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() 方法。这意味着,当调用