python自带的三个装饰器

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

聊到装饰器,就只可以说python自带的八个装饰器:

__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__的天职正是,成立类实例并回到实例。

2、@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做为第贰个参数,隐式的将类实例传递给艺术,调用方法时,类必得实例化。

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

Process finished with exit code 0
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)

 

 

 

3、@staticmethod  修饰类的措施

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

1)是把函数嵌入到类中的一种办法,函数就属于类,同一时间注脚函数无需拜候这些类

Linux and python学习调换3群新开,应接加入,一起学习.qq 3群:563227894

 2)使用修饰服,修饰方法,无需实例化

不前进,不倒退,结束的情形是未曾的.

 

同台发展,与君共勉,

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)

 

 

 

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

Linux and python学习交流3群新开,应接到场,一齐学习.qq 3群:563227894

不前进,不倒退,甘休的景色是从没有过的.

同步前行,与君共勉,

 

本文由星彩网app下载发布于计算机编程,转载请注明出处:python自带的三个装饰器

TAG标签: 星彩网app下载
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。