Python中__init__方法介绍

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值