sam*_*ell 4 java swing exception try-catch
我有一个包含许多类的Java Swing程序.我确实在需要的地方使用try-catchs,但没有其他地方.我还有一个记录器类,它在捕获异常时写入文件.它打印出堆栈跟踪和消息.
我希望能够记录每个异常,但不要在任何地方放置try-catch.这可能吗?
- 编辑(我的主要方法) -
public class Bacon extends Thread implements UncaughtExceptionHandler {
public static Bacon instance = null;
private JFrame main;
private Bacon() {
main = new JFrame("Bacon");
main.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
main.addWindowListener(new WindowEventHandler());
setLAF();
main.setSize(Constants.MAIN_DIMENSION);
main.setLocationRelativeTo(null);
main.setExtendedState(JFrame.MAXIMIZED_BOTH);
main.setIconImage(getIcon());
setUserName();
setUncaughtExceptionHandler(this);
main.setJMenuBar(Menu.getInstance());
main.setContentPane(getMainPanel());
main.setVisible(true);
}
public static Bacon getInstance() {
if(instance == null)
instance = new Bacon();
return instance;
}
private JPanel getMainPanel() {
JPanel main = new JPanel(new BorderLayout());
main.add(Tabs.getInstance(), BorderLayout.CENTER);
main.add(StatusBar.getInstance(), BorderLayout.SOUTH);
return main;
}
.
.
.
.
.
.
.
public static void main(String[] args) {
try {
getInstance();
} catch (Throwable t) {
ErrorLogging.log(t.getStackTrace(), t.getMessage());
}
}
@Override
public void uncaughtException(Thread t, Throwable e) {
ErrorLogging.log(e.getStackTrace(), e.getMessage());
}
}
Run Code Online (Sandbox Code Playgroud)
您捕获了尽可能多的try封装,因此在您的main方法中放置了一个周围的try块和catch(Throwable)以确保捕获所有可能抛出的东西。
不过,最好在发生异常时单独处理异常。