注意1、__init__并不相当于C#中的构造函数,执行它的时候,实例已构造出来了。class A(object):
def __init__(self,name):
self.name=name
def getName(self):
return 'A '+self.name
当我们执行a=A('hello')
时,可以理解为a=object.__new__(A)
A.__init__(a,'hello')
即__init__作用是初始化已实例化后的对象。
注意2、子类可以不重写__init__,实例化子类时,会自动调用超类中已定义的__init__class B(A):
def getName(self):
return 'B '+self.name
if __name__=='__main__':
b=B('hello')
print b.getName()
但如果重写了__init__,实例化子类时,则不会隐式的再去调用超类中已定义的__init__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__方法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()
本文详细解析了Python中__init__方法的作用及其实现细节,包括其与C#构造函数的区别,以及在类继承中如何正确地重写__init__方法以确保父类属性能够被正确初始化。
4723

被折叠的 条评论
为什么被折叠?



