Tomaž Šolc <tomaz.s...@tablix.org> added the comment:

The way I see it is that Charles-François' patch trades a possibility of a 
deadlock for a possibility of a child process running with inconsistent states 
due to forcibly reinitialized locks.

Personally, I would rather have an occasional deadlock than an occasional 
random crash.

I don't like increasing complexity with fine-grained locking either. While the 
general case is unsolvable what Giovanni proposed at least solves the specific 
case where only the basic IO code is involved after a fork. In hindsight the 
only real life use-case I can find that it would solve is doing an exec() right 
after a fork().

There are quite a few bugs in the tracker that seem to have this same root 
cause, so it appears the impossibility of cleanly handling threads and forks is 
not something people are generally aware of. Since I think we agree you can't 
just disable fork() when multiple threads are running, how about at least 
issuing a warning in that case? That would be a two-line change in threading.py.

----------

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

Reply via email to