Message206028
Hum...
Correct me if I'm wrong, but destroying the thread state of daemon threads
while they're running is really a bad idea in fact: for example, if
warnings are now emitted for unclosed file objects, this means that the
file object, and all associated buffers, are destroyed.
But even though the daemon thread doesn't hold the GIL, he might still be
using this object.
For example, if we have:
daemon thread:
readinto:
release_gil
read(fd, fileobj->buffer, fileobj->size)
acquire_gil
and the main thread exits, then fileobj will be deallocated.
It's actually fairly easy to write a short crasher launching a deamon
thread reading from e.g. /dev/zero in loop, with the main thread exiting
right in the middle. |
|
Date |
User |
Action |
Args |
2013-12-13 08:30:38 | neologix | set | recipients:
+ neologix, pitrou, vstinner, Arfrever, python-dev, serhiy.storchaka, vajrasky |
2013-12-13 08:30:38 | neologix | link | issue19466 messages |
2013-12-13 08:30:37 | neologix | create | |
|