本文探讨一点子类继承的差异,基于python 2.x和python 3.x的差异。
如下为python3的代码样例,注意super()的用法。
#python 3
class Person():
def __init__(self, name, age):
self._name = name
self._age = age
def foo(self):
pass
class Student(Person):
def __init__(self, name, age, grade):
super().__init(name, age)
self._grade = grade
def foo2()
pass
if __name__ == '__main__':
s1 = Student('张三', 16, '高一')
s1.foo2()
上述代码在python2.x版本会报错,“TypeError: must be type, not classobj”。查询资料后发现,python子类继承重写函数,有两种写法:
#写法1
Person.__init__(self, name, age)
#写法2
super(Student, self).__init__(name, age)
而写法2,仍抱错“TypeError: must be type, not classobj”,继续查资料,发现在python2.x版本下,子类必须继承object基础类【才为新式类】,否则为经典类。
写法2最终改写,则可运行通过。
class Person():
def __init__(self, name, age):
self._name = name
self._age = age
def foo(self):
pass
class Student(Person, object):
def __init__(self, name, age, grade):
super(Student, self).__init__(name, age)
self._grade = grade
def foo(self):
pass
if __name__ == '__main__':
s1 = Student('章三', 16, '高一')
s1.foo()
注:
- 经典类是深度优先原则,新式类是广度优先原则;
- 经典类是先深入继承树左侧查找,然后再返回,开始查找右侧;
- 新式类是先在水平方向查找,然后再向上查找。