我有一个包含许多类的 Java Swing 程序。我确实在需要的地方使用了 try-catch,但没有在其他地方使用。我还有一个记录器类,它在捕获到异常时写入文件。它打印出堆栈跟踪和消息。
我希望能够记录每个异常,但又不会到处都放 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());
}
}