如何记录未捕获的QApplication异常?

时间:2012-05-19 13:40:06

标签: qt4 pyqt4

我应该在哪里使用except块来记录QApplication的异常?

这似乎不起作用:

app = QtGui.QApplication(sys.argv)
MainWindow = MainWindow()
MainWindow.show()
try:
    eventLoop = app.exec_()
except Exception, e:
    log.exception(str(e))

因为例外甚至不会到达那个区块。

2 个答案:

答案 0 :(得分:5)

Qt不支持从事件处理程序中抛出异常。您必须重新实现QApplication :: notify()并捕获所有异常。

覆盖函数bool QApplication :: notify(QObject * receiver,QEvent * event),以便捕获所有抛出的异常。

你可以这样实现。

virtual bool notify(QObject * receiver, QEvent * event) 
{
     try 
     {
     return QApplication::notify(receiver, event);
     } 
     catch(std::exception& e) 
     {
      qDebug() << "Exception thrown:" << e.what();
     }
}

答案 1 :(得分:0)

我通过覆盖excepthook解决了这个问题,如下面的答案所示:Logging All Exceptions in a pyqt4 app