有人能解释一下为什么以下代码会表现出它的行为吗:
import types
class Dummy():
def __init__(self, name):
self.name = name
def __del__(self):
print "delete",self.name
d1 = Dummy("d1")
del d1
d1 = None
print "after d1"
d2 = Dummy("d2")
def func(self):
print "func called"
d2.func = types.MethodType(func, d2)
d2.func()
del d2
d2 = None
print "after d2"
d3 = Dummy("d3")
def func(self):
print "func called"
d3.func = types.MethodType(func, d3)
d3.func()
d3.func = None
del d3
d3 = None
print "after d3"
输出结果是这样的(请注意,d2的析构函数从未被调用)(Python 2.7)
delete d1
after d1
func called
after d2
func called
delete d3
after d3
有没有一种方法可以“修复”代码,使析构函数在不删除已添加的方法的情况下被调用?我的意思是,最好将d2.func = None放在析构函数中!谢谢
[编辑] 根据前几个答案,我想澄清一下,我不是在问使用__del__的优点(或缺点)。我试图创建一个最短的函数来演示我认为非直观的行为。我假设已经创建了循环引用,但我不确定原因。如果可能的话,我想知道如何避免循环引用....
types.MethodType(func, d2)
引用了d2
并将其放在d2
上,因此你有一个循环引用。这并不奇怪,但如果这不是你想要的,那你为什么要这样做呢? - Jochen Ritzel