mg娱乐电子4355_mg娱乐电子游戏平台
做最好的网站

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

时间:2019-11-03 00:42来源:计算机编程
__init__与__new__区别: python中的__init__ 、__new__、__call__小结,__init___new__ 这篇文章主要介绍了python中的__init__、__new__、__call__小结,需要的朋友可以参考下 1.__new__(cls, *args, **kwargs) 创建对

__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(单例模式)实现,那我们是不是只是重载一些__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?')

结果:

编辑:计算机编程 本文来源:python中的__init__ 、__new__、__call__小结,__init___new__

关键词: