Bie*_*aja 6 java logging eclipse-rcp
我想在我的RCP
应用程序中覆盖全局异常处理.每当发生未被捕获的异常时,我想记录它(使用java
日志记录),然后退出应用程序.我已经eventLoopException(Throwable exception)
在ApplicationWorkbenchAdvisor
课堂上覆盖了这个方法.但这只捕获事件循环异常.截至目前,我还覆盖了postStartup()
这样的方法:
public void postStartup()
{
Policy.setStatusHandler(new StatusHandler()
{
@Override
public void show(IStatus status, String title)
{
LOGGER.log(Level.SEVERE, "Uncaught Exception", status.getException());
UnexpectedErrorDialog();
PlatformUI.getWorkbench().close();
}
});
}
Run Code Online (Sandbox Code Playgroud)
它将异常记录在我的日志文件中并退出应用程序.但它显然不对,并且在控制台中显示两次异常,因为我所做的只是拦截a中的异常显示gui dialog
给用户.那么如何才能正确覆盖/更改全局异常处理,以便使用我的代码(log)而不是默认代码?
感谢 sambi reddy 的提示,我现在已经覆盖了 ApplicationWorkbenchAdvisor 类中的 AbstractStatusHandler
@Override
public synchronized AbstractStatusHandler getWorkbenchErrorHandler() {
if (myStatusHandler == null) {
myStatusHandler = new MyStatusHandler();
}
return myStatusHandler;
}
Run Code Online (Sandbox Code Playgroud)
MyStatusHandler 扩展了 AbstractStatusHandler 并且我已经重写了句柄方法,如下所示:
@Override
public void handle(StatusAdapter statusAdapter, int style)
{
if(statusAdapter.getStatus().matches(IStatus.ERROR) && ((style != StatusManager.NONE)))
{
LOGGER.log(Level.SEVERE, "Uncaught Exception", statusAdapter.getStatus().getException());
UnexpectedErrorDialog();
PlatformUI.getWorkbench().close();
}
}
Run Code Online (Sandbox Code Playgroud)
似乎工作正常,唯一的缺点是我仍然得到 2 个控制台输出。