精心一些,通过参数会有所察觉,其实__init__(self)
self隐式的将,实例传过来。
那篇小说重要介绍了python中的__init__
、__new__、__call__小结,供给的心上人能够参见下
1.__www.2979.com,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(单例方式卡塔 尔(英语:State of Qatar)达成,那我们是否只是重载一些__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__
、__www.2979.com实例传过来,带修饰类方法。new__、__call__小结,必要的恋人能够参照他事他说加以考察下 1.__new…
不前行,不倒退,甘休的状态是还未有的.
@property 修饰,就是将艺术,产生三性格质来使用。
__init__与__new__区别:
3、@staticmethod
修饰类的秘技
__init__在python,其实是,在实例化之后实施的,用来开端化一些属性,约等于构造函数,但是又不均等
Linux and
python学习交换3群新开,招待插手,一同学习.qq 3群:563227894
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?')
Linux and
python学习交换1,2群已满.
Linux and
python学习沟通1,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
联机前行,与君共勉,
带修饰类方法:cls做为方法的率先个参数,隐式的将类做为对象,传递给艺术,调用时不用实例化。
结果:
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)
__new__在python中其实是,在实例化此前试行的,那一个通过参数雷同能够看出
1、@property
将某函数,做为属性使用
C:Python27python.exe D:/weixin/temp/abc.py
__new__
what?
__init__
Process finished with exit code 0
Linux and
python学习沟通3群新开,招待参加,一齐学习.qq 3群:563227894
平日函数方法:self做为第二个参数,隐式的将类实例传递给艺术,调用方法时,类必须实例化。
2、@classmethod
修饰类的章程
1)是把函数嵌入到类中的大器晚成种形式,函数就归于类,同一时间注明函数无需拜会那么些类
2)使用修饰性格很顽强在艰难困苦或巨大压力面前不屈,修饰方法,没有须求实例化
提起装饰器,就不能不说python自带的八个装饰器:
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)
一路前进,与君共勉,
不前行,不倒退,结束的境况是未曾的.