您的位置:澳门新葡8455最新网站 > 编程教学 > Python基础(十) __init__与__new__区别

Python基础(十) __init__与__new__区别

发布时间:2019-11-04 10:57编辑:编程教学浏览(106)

    __init__与__new__区别:

    python中的__init__ 、__new__、__call__小结,__init___new__

    那篇文章重要介绍了python中的__init__ 、__new__、__call__总计,须求的意中人能够参照下

    1.__new__(cls, *args, **kwargs)  创制对象时调用,重回当前指标的二个实例;注意:这里的首先个参数是cls即class本身
    2.__init__(self, *args, **kwargs) 创建完对象后调用,对眼下目的的实例的风姿洒脱部分初阶化,无再次回到值,即在调用__new__自此,根据重回的实例初阶化;注意,这里的首先个参数是self即对象自己【注意和new的界别】
    3.__call__(self,  *args, **kwargs) 固然类达成了那一个方式,也就是把那一个类其余对象充任函数来利用,也就是重载了括号运算符  

    看现实的例子:

    复制代码 代码如下:
    class O(object):

        def __init__(self, *args, **kwargs):
            print "init"
            super(O, self).__init__(*args, **kwargs)

        def __new__(cls, *args, **kwargs):
            print "new", cls
            return super(O, cls).__new__(cls, *args, **kwargs)

        def __call__(self,  *args, **kwargs):
            print "call"       

        oo = O()
        print "________"
        oo() 

    打印出来的是:
    复制代码 代码如下:
    new
    init
    ________
    call
    比如:Python Singleton(单例方式卡塔 尔(英语:State of Qatar)完结,那大家是否只是重载一些__new__艺术就足以了
    复制代码 代码如下:
    class Singleton1(object):
        """ 重载new方法"""
        def __new__(cls, *args, **kwargs):
            if not "_instance" in vars(cls):
                cls._instance = super(Singleton1, cls).__new__(cls, *args, **kwargs)
            return cls._instance

    同意能够重载__init__艺术吧?分明不得以,因为__init__从前调用了__new__措施,此时已经变化了二个对象了,不可能贯彻单例形式

    ===========================================  

    注意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()    

    、__new__、__call__小结,__init___new__ 那篇随笔首要介绍了python中的__init__ 、__new__、__call__小结,必要的冤家能够参见下 1.__new...

    __init__在python,其实是,在实例化之后履行的,用来初始化一些属性,也等于构造函数,不过又不均等

    紧凑一些,通过参数会具备察觉,其实__init__(self)  self隐式的将,实例传过来。

     

    __new__在python中实际上是,在实例化以前实行的,那么些通过参数同样能够见见

    __new__(cls),cls是隐式的传递的类对象,并非实例。因为__new__的天职正是,创建类实例并赶回实例。

    class temp(object):
    
        def __init__(self,txt):
            self.txt = txt
            print '__init__'
    
    
        def __new__(cls,txt):
            print '__new__'
            print txt
            return super(temp,cls).__new__(cls)
    
    temp('what?')
    

    结果:

    C:Python27python.exe D:/weixin/temp/abc.py
    __new__
    what?
    __init__
    
    Process finished with exit code 0
    

     

     

    Linux and python学习交换1,2群已满.

    Linux and python学习调换3群新开,款待参加,一同学习.qq 3群:563227894

    不前行,不倒退,截止的景况是不曾的.

    一起前进,与君共勉,

     

    本文由澳门新葡8455最新网站发布于编程教学,转载请注明出处:Python基础(十) __init__与__new__区别

    关键词: