代码A:
# -*- coding:gb2312 -*-
class Dog (object):
def __init__(self):
print("-----init方法-----")
def __del__(self):
print("-----del方法-----")
def __str__(self):
#print("-----str方法-----")
return ("-----str方法-----")
def __new__(cls):
print("-----new方法-----")
#return object.__new__(cls)
xtq = Dog()
代码A运行结果:
代码B:
# -*- coding:gb2312 -*-
class Dog (object):
def __init__(self):
print("-----init方法-----")
def __del__(self):
print("-----del方法-----")
def __str__(self):
#print("-----str方法-----")
return ("-----str方法-----")
def __new__(cls):
print("-----new方法-----")
object.__new__(cls)
xtq = Dog()
代码B运行结果:
代码C:
# -*- coding:gb2312 -*-
class Dog (object):
def __init__(self):
print("-----init方法-----")
def __del__(self):
print("-----del方法-----")
def __str__(self):
#print("-----str方法-----")
return ("-----str方法-----")
def __new__(cls):
print("-----new方法-----")
return object.__new__(cls)
xtq = Dog()
代码C运行结果:
我的问题一:
这三段代码A,B,C为什么输出的结果都不一样,原理在于哪里呢?特别是代码B和代码C,为什么代码C这一段,在B的基础上加上了return,结果就比B多了一个init方法。
我的问题二:
在给方法传参数的时候self和cls 这两个参数有啥区别?为什么__new__这个方法要的参数是cls而__init__方法要传入的参数是self?
过去多啦不再A梦2017-06-28 09:26:55
首先得先明白一件事情: self
和cls
的区别, cls
是代表这个类
, slef
是用来代表这个类的实例
, 如果这个搞清楚, 就成功了一点.
函数参数带有self
的, 可以理解成这个函数, 是实例的方法, 是要和实例绑定的.
__new__
方法, 是新式类用来创建实例使用的, 传入的cls
就是用来给object.__new__
创建实例使用的参数, 如果没有传入cls
, object
根本不知道创建什么样的实例.
结合上面, 现在再来说下三个输出不同的原因:
为什么只有--new, 因为每个类在实例化对象时, 都必须要调用这个__new__
方法, 去创建实例, 所以它肯定会被调用, 但是因为该函数被你重写了, 所以它只是打印了--new方法
, 并没有返回创建实例, 并且放回, 所以__del__
也是不会发生
为什么只有--new和--del, 正如第1点说的那样, 但是这里确实__new___
有创建新实例, 但是并没有返回, 因为只有返回了, 该对象才能进行下一步的__init__
, 正因为这里只有创建, 没有返回, 所以结果这样
如果看懂前两点, 相信这个应该没啥问题, 因为创建了,并且返回了, 所以'__init__'也同样被执行了, 所有的东西都是像正常的行为那样发生
最后想说明: 为什么__del__
会被执行, 理论上, 这个只有在实例被del
析构时, 才会执行,这里并没有del xtq
类似的代码, 为什么也会执行, 原因就是, 程序结束了, 要退出了, 在执行更底层的程序退出时, python
自发做的内存回收, 所以一切尘归尘土归土, 创建的对象也被一一析构