当前位置: 首页 > 面试题库 >

JavaFX 2-捕获所有运行时异常

勾海超
2023-03-14
问题内容

我试过了

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:)