在Python中
- 需要注意一点:
类的__init__方法是初始化方法,而 __new__方法是创建实例的方法
__init__有一个参数self,就是这个__new__返回的实例,__init__在__new__的基础上可以完成一些其它初始化的动作,__init__不需要返回值 - 当我们初始化一个类时
首先调用的是__new__方法,其次调用的才是__init__方法
__new__至少要有一个参数cls,代表要实例化的类,此参数在实例化时由Python解释器自动提供
__new__必须要有返回值,返回实例化出来的实例,这点在自己实现__new__时要特别注意,可以return父类 __new__出来的实例,或者直接是object的__new__出来的实例 - __new__先被调用,__init__后被调用,__new__的返回值(实例)将传递给__init__方法的第一个参数,然后__init__给这个实例设置一些参数。
如下尝试python3.6中
class per(object):
def __init__(self,a):
print('__init__')
self.a = a
def __new__(cls,*args,**kwargs):
print('__new__')
# return super().__new__(cls)
return object.__new__(cls)
if __name__ == '__main__':
per('123')
打印顺序结果如下所示
C:\python3.6\python.exe D:/Python/data_object/test3.py
__new__
__init__
- TypeError: object() takes no parameters的处理;意思是object()不需要传进参数。
需要注意其中变量名中前后是有两个下划线(_)否则也会报错
在python2.7中可以按照下面这样写,但是在python3.6会报错;
我们可以按照上面的方式 return object.new(cls) 或者 super().new(cls) 返回实例
class per(object):
def __init__(self,a):
print('__init__')
self.a = a
def __new__(cls,*args,**kwargs):
print('__new__')
return object.__new__(cls,*args,**wargs) # 这里
if __name__ == '__main__':
per('123')