initi运行的时候对象已经创建了,姑且认为c++的构造函数=python创建+init
__init__方法在类的一个对象被建立时,马上运行。这个方法可以用来对你的对象做一些你希望的 初始化 。注意,这个名称的开始和结尾都是双下划线。
它如何工作
最重要的是,我们没有专门调用__init__方法,只是在创建一个类的新实例的时候,把参数包括在圆括号内跟在类名后面,从而传递给__init__方法。这是这种方法的重要之处。
__init__方法类似于C 、C#和Java中的 constructor
Python中__init__方法注意点
注意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()
|
转载自http://www.2cto.com/kf/201009/74919.html
http://www.cnblogs.com/zyxstar2003/archive/2011/03/21/1989954.html