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方法,这时候已经生成了一个对象了,没办法实现单例模式