python 2.6.x theading / signal / atexit не работает в некоторых версиях?

Я видел много вопросов по этому поводу ... но мой код работает на python 2.6.2, а не работает на python 2.6.5. Я ошибаюсь, думая, что все функции atexit, зарегистрированные с помощью этого модуля, не вызываются, когда программа прерывается сигналом, что не должно здесь учитываться, потому что я ловлю сигнал и затем чисто выхожу? Что тут происходит? Как правильно это сделать?

import atexit, sys, signal, time, threading

terminate = False
threads = []

def test_loop():
    while True:
        if terminate:
            print('stopping thread')
            break
        else:
            print('looping')
            time.sleep(1)

@atexit.register
def shutdown():
    global terminate
    print('shutdown detected')
    terminate = True
    for thread in threads:
        thread.join()

def close_handler(signum, frame):
    print('caught signal')
    sys.exit(0)

def run():
    global threads
    thread = threading.Thread(target=test_loop)
    thread.start()
    threads.append(thread)

    while True:
        time.sleep(2)
        print('main')

signal.signal(signal.SIGINT, close_handler)

if __name__ == "__main__":
    run()

python 2.6.2:

$ python halp.py 
looping
looping
looping
main
looping
main
looping
looping
looping
main
looping
^Ccaught signal
shutdown detected
stopping thread

python 2.6.5:

$ python halp.py 
looping
looping
looping
main
looping
looping
main
looping
looping
main
^Ccaught signal
looping
looping
looping
looping
...
looping
looping
Killed <- kill -9 process at this point

Похоже, что основной поток 2.6.5 никогда не выполняет функции atexit.

5
задан lostincode 14 September 2010 в 22:24
поделиться