菜单

【澳门金沙国际】python中的__init__ 、__new__、__call__小结

2019年3月28日 - 金沙编程资讯

同步发展,与君共勉,

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

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…

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

 

 @property 修饰,便是将艺术,变成叁天质量来采用。

1.__new__(cls, *args, **kwargs) 
成立对象时调用,重返当前指标的3个实例;注意:那里的首先个参数是cls即class自己
2.__init__(self, *args, **kwargs)
创设完对象后调用,对日前指标的实例的部分初叶化,无重回值,即在调用__new__后来,依照再次来到的实例初阶化;注意,那里的率先个参数是self即对象自作者【注意和new的分别】
3.__call__(self,  *args, **kwargs)
假使类完结了这么些办法,相当于把那些类型的目的当作函数来使用,相当于重载了括号运算符
 

__new__在python中其实是,在实例化从前实施的,那么些通过参数一样能够见见

 

复制代码 代码如下:

仔细一些,通过参数会有所发现,其实__init__(self)
 self隐式的将,实例传过来。

带修饰类方法:cls做为方法的首先个参数,隐式的将类做为对象,传递给艺术,调用时毫无实例化。

1
a=A('hello')
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?')
class A():
    def func(self,x,y):
        return x * y


    @staticmethod
    def sfunc(x,y):
        return x * y


if __name__=="__main__":

    print A.sfunc(6,5)
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()
 
 

不前进,不倒退,甘休的情况是未曾的.

② 、@classmethod
 修饰类的办法

这篇作品首要介绍了python中的__init__
、__new__、__call__总括,需求的情人能够参见下

Linux and
python学习沟通1,2群已满.

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)

class O(object):

__init__与__new__区别:

1)是把函数嵌入到类中的一种艺术,函数就属于类,同时注脚函数不需求拜访那一个类

打印出来的是:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图