Tim Peters <t...@python.org> added the comment:

What makes you think that? Your own output shows that the number of "Active" 
objects does NOT monotonically increase across output lines. It goes up 
sometimes, and down sometimes.  Whether it goes up or down is entirely due to 
accidents of when your monitoring thread happens to wake up during the lifetime 
of the program's gc history.

I boosted the loop count to 10 million on my box just now. It had no 
significant effect on peak memory use. At the end:

>>> A.COUNT, A.TOTAL, B.COUNT, B.TOTAL
(298, 10000000, 298, 10000000)
>>> gc.collect()
1188
>>> A.COUNT, A.TOTAL, B.COUNT, B.TOTAL
(1, 10000000, 1, 10000000)

There is no leak. An A and B object survive collect() because the last A object 
created remains bound to the variable `a` used in the loop (so is still 
reachable).

So I thank you for creating a nice test program, but I'm closing this since it 
doesn't demonstrate a real problem.

----------
resolution:  -> not a bug
stage:  -> resolved
status: open -> closed

_______________________________________
Python tracker <rep...@bugs.python.org>
<https://bugs.python.org/issue41389>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to