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.zhihu.com/question/22475395/answer/66944861
来源:知乎