Может кто-нибудь объяснить, почему следующий код ведет себя так:
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 было бы в деструкторе!
Спасибо
[edit] Основываясь на первых нескольких ответах, я хотел бы пояснить, что я не спрашиваю о достоинствах (или их отсутствии) использования __del__
. Я попытался создать самую короткую функцию, которая продемонстрировала бы то, что я считаю неинтуитивным. Я предполагаю, что круговая ссылка была создана, но я не знаю, почему. Если возможно, я хотел бы знать, как избежать круговой ссылки....