python的 __init__ 理解
2017-06-16 15:13
344 查看
文章参考:http://www.cnblogs.com/zyxstar2003/archive/2011/03/21/1989954.html
注意1、__init__并不相当于C#中的构造函数,执行它的时候,实例已构造出来了。
当我们执行
注意2、子类可以不重写__init__,实例化子类时,会自动调用超类中已定义的__init__
但如果重写了__init__,实例化子类时,则不会隐式的再去调用超类中已定义的__init__
则会报"AttributeError: 'C' object has no attribute 'name'”错误,所以如果重写了__init__,为了能使用或扩展超类中的行为,最好显式的调用超类的__init__方法
注意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中的__new__与__init__魔术方法理解笔记
- [python]对self和_init_的理解
- 对于python官方doc中相对路径重复init的理解和实验
- python面向对象中的__init__方法怎么理解?
- 深入理解Python中的 __new__ 和 __init__及区别介绍
- Python | 关于 类、实例、self、__init__ 的理解
- Python中的__new__与__init__魔术方法理解笔记
- 如何理解 Python 中的__init__
- python中self cls init的理解
- 如何理解并正确使用python中的self init
- 理解python中的__str__, __call__, __init__, __getattr__
- 对/etc/rc.d/init.d目录的一点理解
- 对/etc/rc.d/init.d/目录的一点理解
- Python天天美味(33) - 五分钟理解元类(Metaclasses)[转]
- python self,cls,decorator的理解
- [Python -and or ]Python 中 and or 之 我的理解
- [Python]五分钟理解元类(Metaclasses)
- D:/Python26/lib/site-packages/MySQLdb/__init__.py:34: DeprecationWarning: the sets module is deprecated from sets import Immut
- 理解python中的bytestring和unicode
- Python模块包中__init__.py文件的作用