#多态:不同的子类对象调用相同的父类方法,产生不同的执行结果
#多态可以添加代码的灵活度
#以继承和重写父类方法为前提:
#多态:不同的子类对象调用相同的父类方法,产生不同的执行结果
#多态可以添加代码的灵活度
#以继承和重写父类方法为前提
class Cat:
def __init__(self,name):
self.name=name;
def play(self):
print("我是:",self.name);
class Kitty(Cat):
def play(self):
print("我是猫的子类:",self.name)
class People(object):
def __init__(self,name):
self.name=name;
def peopleAndCat(self,d):
print("我是%s 的主人:%s"%(d.name,self.name))
c=Cat("天猫");
#c=Kitty("勀体");
c.play()
p=People("小明");
p.peopleAndCat(c)
结果:
#多态:不同的子类对象调用相同的父类方法,产生不同的执行结果
#多态可以添加代码的灵活度
#以继承和重写父类方法为前提
class Cat:
def __init__(self,name):
self.name=name;
def play(self):
print("我是:",self.name);
class Kitty(Cat):
def play(self):
print("我是猫的子类:",self.name)
class People(object):
def __init__(self,name):
self.name=name;
def peopleAndCat(self,d):
print("我是%s 的主人:%s"%(d.name,self.name))
#c=Cat("天猫");
c=Kitty("勀体");
c.play()
p=People("小明");
p.peopleAndCat(c)
结果为:
c是Kitty类型,它实际上拥有自己的play()方法以及从 Cat继承的 play方法,但调用 c.play()总是先查找它自身的定义,如果没有定义,则顺着继承链向上查找,直到在某个父类中找到为止。
由于Python是动态语言,所以,传递给函数 peopleAndCat的参数 d不一定是 Cat 或 Cat 的子类型。任何数据类型的实例都可以,只要它有一个play()的方法即可:
这就是python的多态,和java的多态有区别