本文探讨一点子类继承的差异,基于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()
            
          
          注:
- 经典类是深度优先原则,新式类是广度优先原则;
- 经典类是先深入继承树左侧查找,然后再返回,开始查找右侧;
- 新式类是先在水平方向查找,然后再向上查找。


 
					 
					