【python】继承时注意事项

1. __init__ 注意事项

如果父类有__init__函数,子类没有,则子类自动调用父类__init__函数

如果父类有__init__函数,子类也有,则子类必须主动调用父类__init__函数,否则会报错

class A:
    def __init__(self):
        self.name = "A"
    def PrintName(self):
        print self.name
    
class B(A):
    def __init__(self):
        A.__init__(self)
        self.__age = 18
    
    
obj = B()
obj.PrintName()

下面讲解来源:http://www.cnblogs.com/zyxstar2003/archive/2011/03/21/1989954.html

注意1、__init__并不相当于C#中的构造函数,执行它的时候,实例已构造出来了。

1
2
3
4
5
class A(object):
    def __init__(self,name):
        self.name=name
    def getName(self):
        return 'A '+self.name

当我们执行

1
a=A('hello')

时,可以理解为

1
2
a=object.__new__(A)
A.__init__(a,'hello')

即__init__作用是初始化已实例化后的对象。

注意2、子类可以不重写__init__,实例化子类时,会自动调用超类中已定义的__init__

1
2
3
4
5
6
7
class B(A):
    def getName(self):
        return 'B '+self.name
 
if __name__=='__main__':
    b=B('hello')
    print b.getName()

但如果重写了__init__,实例化子类时,则不会隐式的再去调用超类中已定义的__init__

1
2
3
4
5
6
7
8
9
class C(A):
    def __init__(self):
        pass
    def getName(self):
        return 'C '+self.name
 
if __name__=='__main__':
    c=C()
    print c.getName()

则会报"AttributeError: 'C' object has no attribute 'name'”错误,所以如果重写了__init__,为了能使用或扩展超类中的行为,最好显式的调用超类的__init__方法

1
2
3
4
5
6
7
8
9
class C(A):
    def __init__(self,name):
        super(C,self).__init__(name)
    def getName(self):
        return 'C '+self.name
 
if __name__=='__main__':
    c=C('hello')   
    print c.getName()

2.继承有普通继承和super继承两种

3.python类有新式类和经典类

区别:
1)首先,写法不一样:
class A:
    pass

class B(object):
    pass
2)在多继承中,新式类采用广度优先搜索,而旧式类是采用深度优先搜索。
3)新式类更符合OOP编程思想,统一了python中的类型机制。
4)旧类无法使用super
5)新类的类型是type
 
作者:Jack Twain/Zeno
链接:https://www.zhihu.com/question/22475395/answer/66944861
来源:知乎
原文地址:https://www.cnblogs.com/dplearning/p/5126733.html