Python基础(七) python自带的多少个装饰器

__init__与__new__区别:

说起装饰器,就只可以说python自带的多少个装饰器:

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

那篇作品首要介绍了python中的__init__
、__new__、__call__小结,供给的情人能够参照下

1.__new__(cls, *args, **kwargs) 
成立对象时调用,再次来到当前指标的八个实例;注意:那里的第2个参数是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个对象了,不能落到实处单例方式

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

注意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__总计,必要的朋友能够参照下 ①.__new…

__init__在python,其实是,在实例化之后执行的,用来初叶化1些性质,相当于构造函数,可是又不雷同

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

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

 @property 修饰,正是将艺术,变成二本性质来使用。

 

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

__new__在python中实际是,在实例化此前实施的,那么些通过参数壹样能够看出

 

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

二、@classmethod
 修饰类的艺术

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?')

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

结果:

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

发表评论

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