首页登陆欢迎您!
首页登陆 > 编程 > Python基础(十) __init__与__new__区别

Python基础(十) __init__与__new__区别

时间:2019-12-13

 

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...

class A():
    def func(self,x,y):
        return x * y

    @classmethod
    def cfunc(cls,x,y):
        return x * y

if __name__=="__main__":
    print A().func(5,5)
    print A.cfunc(4,5)

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

 

 

日常函数方法:self做为第三个参数,隐式的将类实例传递给艺术,调用方法时,类必须实例化。

细心一些,通过参数会有着开采,其实__init__(self卡塔尔(قطر‎ self隐式的将,实例传过来。

 @property 修饰,便是将艺术,产生三个天性来利用。

__init__与__new__区别:

 

C:Python27python.exe D:/weixin/temp/abc.py
__new__
what?
__init__

Process finished with exit code 0

1、@property   将某函数,做为属性使用

 

 2卡塔尔使用修饰泰山压顶不弯腰,修饰方法,无需实例化

__new__(cls卡塔尔国,cls是隐式的传递的类对象,实际不是实例。因为__new__的天职正是,创造类实例并赶回实例。

class A():


    @property
    def pfunc(self):
        return self.value

    @pfunc.setter
    def pfunc(self,value):
        self.value = value

    @property
    def pfunc1(self):
        print('this is property')

if __name__=="__main__":

    A.pfunc = 9
    print A.pfunc
    A.pfunc1
上一篇:深深解答有关Python的11道基本面试题,python11道 下一篇:没有了