python 2.x子类继承重写坑

本文探讨一点子类继承的差异,基于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()

注:

  1. 经典类是深度优先原则,新式类是广度优先原则;
  2. 经典类是先深入继承树左侧查找,然后再返回,开始查找右侧;
  3. 新式类是先在水平方向查找,然后再向上查找。

你可能感兴趣的:(python2)