我试过了
Thread.setDefaultUncaughtExceptionHandler...
在主方法中,在start(Stage primaryStage)方法中也是如此。它没有用。
我也试过
public static void main(String[] args) {
try {
launch(args);
}catch(Throwable t) {
System.out.println(t.getMessage);
}
}
异常堆栈跟踪。
在javafx.concurrent.Task $ TaskCallable $
2.run(Task.java:1251)在com.sun.javafx.application.PlatformImpl $
3.run(PlatformImpl.java:141)在com.sun.glass.ui.gtk.GtkApplication
._runLoop(本机方法),位于com.sun.glass.ui.gtk.GtkApplication $ 1 $
1.run(GtkApplication.java:56),位于java.lang.Thread.run(Thread.java:662)
感谢您的帮助。
如果检查代码Platform.runLater()
(见下文),您将看到异常被吞没(第146/147行),因此默认的未捕获异常处理程序将无法捕获它们-
基于该段代码,我不知道除了在可运行对象中包含try / catch块外,您别无选择。
请注意,已经报告了此问题(需要登录-免费注册),并且应该在Lombard中进行修复(=明年与Java 8一起发布的Java FX 8.0)。
您也可以创建一个实用程序方法并调用
Platform.runLater(getFxWrapper(yourRunnable));
public static Runnable getFxWrapper(final Runnable r) {
return new Runnable() {
@Override
public void run() {
try {
r.run();
} catch (Exception e) {
//here you probably want to log something
System.out.println("Found an exception");
}
}
};
}
的代码Platform.runLater
:
120 private static void runLater(final Runnable r, boolean exiting) {
121 if (!initialized.get()) {
122 throw new IllegalStateException("Toolkit not initialized");
123 }
124
125 pendingRunnables.incrementAndGet();
126 waitForStart();
127
128 if (SystemProperties.isDebug()) {
129 Toolkit.getToolkit().pauseCurrentThread();
130 }
131
132 synchronized (runLaterLock) {
133 if (!exiting && toolkitExit.get()) {
134 // Don't schedule a runnable after we have exited the toolkit
135 pendingRunnables.decrementAndGet();
136 return;
137 }
138
139 Toolkit.getToolkit().defer(new Runnable() {
140 @Override public void run() {
141 try {
142 r.run();
143 pendingRunnables.decrementAndGet();
144 checkIdle();
145 } catch (Throwable t) {
146 System.err.println("Exception in runnable");
147 t.printStackTrace();
148 }
149 }
150 });
151 }
152 }
问题 怎样捕获代码中的所有异常? 解决方案 想要捕获所有的异常,可以直接捕获 Exception 即可: try: ... except Exception as e: ... log('Reason:', e) # Important! 这个将会捕获除了 SystemExit 、 KeyboardInterrupt 和 GeneratorExit 之外的所有异常。
我在Laravel 6中遇到了一个错误。我如何解决这个问题? 致命错误:未捕获的RuntimeException:目录名不能为空。在D:\Xampp\htdocs\tolet\vendor\symfony\finder\Iterator\recursivedirectoryiiterator中。php:54堆栈跟踪:#0 D:\Xampp\htdocs\tolet\vendor\symfony\f
出于日志记录的目的,我们正试图通过Spring自己的AOP捕获各种Spring的运行时异常,我必须说我没有成功,所以我非常感谢关于如何实现这一点的任何想法。 我试过这样的方法: 该类是自动代理的,并且方面类中的其余建议被正确地触发,因此必须有一个问题与AbulJ表达式。 更新:方法中的代码不运行,我不打算在通知中捕获异常。 有什么想法吗?Thx提前。 P.S.Spring框架版本为3.0.6。
我目前在我的路由中使用dotry/doCatch块,因此我无法使用全局onException块。 然而,如果驼峰路由中断(由于错误代码或意外/未测试的场景),我希望执行一些业务逻辑。希望这永远不会发生,但我仍然想处理更糟糕的情况。 我不能在全局OneException块中有java.lang.Exception,而且,我不想在每个路由上都添加一个额外的捕获。 在抛出未捕获的异常和中断路由之前,是否
我试图在Jenkins中使用JMeter运行一个非常简单的测试。 JMeter版本2.13 使用windows批处理命令在Jenkins中执行。 在Jenkins中运行作业时,我在控制台输出中收到以下错误消息: 未捕获的异常java.lang.异常。有关详细信息,请参阅日志文件。未捕获的异常java.lang.NoClassDefFoundError:无法初始化类org.apache.jmeter
这个问题不是关于Rollbar tho:)