'sys.excepthook' и многопоточность - PullRequest
15 голосов
/ 29 октября 2009

Я использую Python 2.5 и пытаюсь использовать самоопределение excepthook в моей программе. В основном потоке все работает отлично. Но в потоке, запущенном с модулем потоков, обычно вызывается excepthook.

Вот пример, показывающий проблему. Раскомментирование комментария показывает желаемое поведение.

import threading, sys

def myexcepthook(type, value, tb):
    print 'myexcepthook'

class A(threading.Thread, object):

    def __init__(self):
        threading.Thread.__init__(self, verbose=True)
#       raise Exception('in main')
        self.start()

    def run(self):
        print 'A'
        raise Exception('in thread')            

if __name__ == "__main__":
    sys.excepthook = myexcepthook
    A()

Итак, как я могу использовать свой собственный excepthook в теме?

Ответы [ 2 ]

15 голосов
/ 25 июля 2015

Похоже, что эта ошибка все еще присутствует в (как минимум) 3.4, и один из обходных путей в обсуждении, связанном с Надей Алрамли, похоже, работает и в Python 3.4.

Для удобства и документации я выложу код для (на мой взгляд) лучшего обходного пути здесь. Я немного обновил стиль кодирования и комментарии, чтобы сделать его более PEP8 и Pythonic.

import sys
import threading

def setup_thread_excepthook():
    """
    Workaround for `sys.excepthook` thread bug from:
    http://bugs.python.org/issue1230540

    Call once from the main thread before creating any threads.
    """

    init_original = threading.Thread.__init__

    def init(self, *args, **kwargs):

        init_original(self, *args, **kwargs)
        run_original = self.run

        def run_with_except_hook(*args2, **kwargs2):
            try:
                run_original(*args2, **kwargs2)
            except Exception:
                sys.excepthook(*sys.exc_info())

        self.run = run_with_except_hook

    threading.Thread.__init__ = init
11 голосов
/ 29 октября 2009

Похоже, здесь сообщается об ошибке с обходными путями. Предлагаемые хаки в основном оборачиваются в try / catch и затем вызывают sys.excepthook(*sys.exc_info())

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...