http://blog.csdn.net/jiesa/article/details/50525309
1.使用demo
初始化 。注意,这个名称的开始和结尾都是双下划线。
使用__init__方法
代码例子
#!/usr/bin/Python
# Filename: class_init.py
class Person:
def __init__(self, name):
self.name = name
def sayHi(self):
print Hello, my name is, self.name
p = Person(Swaroop)
p.sayHi()
# This short example can also be written as Person(Swaroop).sayHi()
输出
$ python class_init.py
Hello, my name is Swaroop
它如何工作
这里,我们把__init__方法定义为取一个参数name(以及普通的参数self)。在这个__init__里,我们只是创建一个新的域,也称为name。注意它们是两个不同的变量,尽管它们有相同的名字。点号使我们能够区分它们。
最重要的是,我们没有专门调用__init__方法,只是在创建一个类的新实例的时候,把参数包括在圆括号内跟在类名后面,从而传递给__init__方法。这是这种方法的重要之处。
现在,我们能够在我们的方法中使用self.name域。这在sayHi方法中得到了验证。
__init__方法类似于C 、C#和Java中的 constructor
2.注意点
注意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()
|