Python基础(十) __init__与__new__区别

2019-11-28 02:37栏目:编程学习

__init__与__new__区别:

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

那篇作品首要介绍了python中的__init__ 、__new__、__威尼斯人app,call__总括,须要的朋友能够参见下

1.__new__(cls, *args, **kwargs)  创造对象时调用,重回当前目的的叁个实例;注意:这里的第贰个参数是cls即class本人
2.__init__(self, *args, **kwargs) 创制完对象后调用,对当下目的的实例的有个别开始化,无重临值,即在调用__new__自此,依照重返的实例最初化;注意,这里的第4个参数是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(单例形式卡塔 尔(阿拉伯语:قطر‎达成,那大家是否只是重载一些__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

不前行,不倒退,结束的境况是未曾的.

一同前进,与君共勉,

 

版权声明:本文由威尼斯人app发布于编程学习,转载请注明出处:Python基础(十) __init__与__new__区别