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__方法,这时候已经生成了一个对象了,没办法实现单例模式
相关推荐
FlySky 2020-09-29
Phplayers 2020-09-05
oXiaoChong 2020-06-03
class Singleton: def __new__: # 关键在于这,每一次实例化的时候,我们都只会返回这同一个instance对象 if not hasattr: cls.instance =
lhxxhl 2020-05-16
laohyx 2020-04-06
pengkunstone 2020-02-22
codeAB 2020-01-19
逍遥友 2019-12-30
typhoonpython 2019-11-19
amazingbo 2019-06-30
pythonxuexi 2019-06-28
ruoyiqing 2016-10-13
cjb 2019-06-28
小方哥哥 2019-06-27
hualicc 2010-05-04
manbucy 2010-03-03
jibkfv 2019-06-20