34-python中多态

类具有继承关系,并且子类类型可以向上转型看做父类类型,如果我们从Person派生出StudentTeacher,并都写了一个whoAmI()方法:

class Person(object):    def __init__(self, name, gender):        self.name = name        self.gender = gender    defwhoAmI(self):        return 'I am a Person, my name is %s' % self.nameclass Student(Person):    def __init__(self, name, gender, score):        super(Student, self).__init__(name, gender)        self.score = score    defwhoAmI(self):        return 'I am a Student, my name is %s' % self.nameclass Teacher(Person):    def __init__(self, name, gender, course):        super(Teacher, self).__init__(name, gender)        self.course = course    defwhoAmI(self):        return 'I am a Teacher, my name is %s' % self.name

在一个函数中,如果我们接收一个变量x,则无论该xPerson、Student还是Teacher,都可以正确打印出结果:

def who_am_i(x):

print x.whoAmI()

p = Person('Tim', 'Male')

s = Student('Bob', 'Male', 88)

t = Teacher('Alice', 'Female', 'English')

who_am_i(p)

who_am_i(s)

who_am_i(t)

运行结果:

I am a Person, my name is Tim

I am a Student, my name is Bob

I am a Teacher, my name is Alice

这种行为称为多态。也就是说,方法调用将作用在x的实际类型上。sStudent类型,它实际上拥有自己的whoAmI()方法以及从 Person继承的 whoAmI方法,但调用s.whoAmI()总是先查找它自身的定义,如果没有定义,则顺着继承链向上查找,直到在某个父类中找到为止。

由于Python是动态语言,所以,传递给函数who_am_i(x)的参数x不一定是 Person 或 Person 的子类型。任何数据类型的实例都可以,只要它有一个whoAmI()的方法即可:

class Book(object):

def whoAmI(self):

return 'I am a book'

这是动态语言和静态语言(例如Java)最大的差别之一。动态语言调用实例方法,不检查类型,只要方法存在,参数正确,就可以调用。

你可能感兴趣的:(34-python中多态)