How to log uncaught exceptions of a QApplication?

2019-04-28 12:07发布

Where should i use an except block in order to log exceptions of a QApplication?

This doesn't seem to work:

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

as the exception won't even reach that block.

标签: qt4 pyqt4
2条回答
Luminary・发光体
2楼-- · 2019-04-28 13:00

I solved it by overriding the excepthook, as seen in the following answer: Logging All Exceptions in a pyqt4 app

查看更多
Animai°情兽
3楼-- · 2019-04-28 13:10

Throwing exceptions from an event handler is not supported in Qt. You must reimplement QApplication::notify() and catch all exceptions there.

Overwrite the function bool QApplication::notify(QObject * receiver, QEvent *event) so that it catches all thrown exceptions.

You can implement like this.

virtual bool notify(QObject * receiver, QEvent * event) 
{
     try 
     {
     return QApplication::notify(receiver, event);
     } 
     catch(std::exception& e) 
     {
      qDebug() << "Exception thrown:" << e.what();
     }
}
查看更多
登录 后发表回答