【问题标题】:JavaFX 2 - Catching all runtime exceptionsJavaFX 2 - 捕获所有运行时异常
【发布时间】:2012-09-01 09:09:59
【问题描述】:

我试过了

Thread.setDefaultUncaughtExceptionHandler...


在 main 和 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(Native Method) 在 com.sun.glass.ui.gtk.GtkApplication$1$1.run(GtkApplication.java:56) 在 java.lang.Thread.run(Thread.java:662)

感谢您的帮助。

【问题讨论】:

  • 您是否尝试捕获所有异常类的基类Throwable

标签: java exception-handling javafx-2


【解决方案1】:

如果您检查Platform.runLater() 的代码(见下文),您将看到异常被吞没(第 146 / 147 行),因此默认的未捕获异常处理程序将无法捕获它们 - 基于此一段代码,我认为你别无选择,只能在你的可运行文件中包含 try/catch 块。

请注意,this issue has been reported(需要登录 - 注册是免费的)并且应该在 Lombard 中修复(= Java FX 8.0 将于明年与 Java 8 一起发布)。

你也可以创建一个实用方法并调用

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");
            }
        }
    };
}

Code of 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     }

【讨论】:

  • 对不起,我让赏金过期了 :-(,虽然我应该把它交给这个答案。放一个新的怎么样?
  • @AgostinoX 它以前发生在我身上 ;-) 你不必这样做。
  • 感谢您指出这一点。但是,您的包装器仅适用于 Runnable 代码中直接引发的异常。例如,如果您在 Runnable 中设置场景,它将在场景构建期间捕获异常,但不会捕获稍后发生的异常,例如通过实际使用场景时的事件...
  • @MartinMeyer 这些其他异常应该是“可捕获的”(即不被吞没)。
  • 与以下相同的评论。包装会起作用吗?看到有问题的异常在(现在是内部线程,直到被吞噬)所以我们会得到那个异常对象的任何信息吗?请原谅我的基本疑问 try { r.run(); //额外代码 } catch (Throwbale t) { t.printStackTrace(); } 是 stackTrace 的 r 吗?
【解决方案2】:

一些托管线程,如 UI 事件处理程序和 ExecutorServices 自己捕获 Throwable 以避免线程死亡。只有死掉的线程才会使用这个 UncaughtExceptionHandler。如果您想捕获抛出的异常,您必须在可以抛出这些异常的方法中执行此操作。

如果 UI 事件处理程序有报告异常的方法,那将是另一种方法。

您的第二个示例将捕获该线程中引发的异常。其他线程抛出的异常会被该线程捕获。

【讨论】:

  • NullPointerException 呢?
  • 所有异常和错误的处理方式相同。
  • 应该有一个优雅的解决方案来解决您的问题。看看源码看看有没有。 ;)
  • 在 Java 7 中,setDefaultUncaughtExceptionHandler 也应该适用于 EDT 线程。对于 Java 6,请参见:stackoverflow.com/questions/5794472/…
  • 我已经设置了赏金,因为在我看来这个问题需要更多的关注。也许我们实际上最终得到了一个不同的异常管理“架构”,基于这个新的“无法捕获”原则,但随后需要示例和解释,因为我们中的许多人正确地认为 setDefaultUncaughtExceptionHandler 应该工作。
【解决方案3】:

将 EventDispatcher 设置为根节点对我有用。

 public class Frame extends Pane {
    Frame() {
        setEventDispatcher(new EventDispatcher() {

            @Override
            public Event dispatchEvent(Event event, EventDispatchChain chain) {
                try {
                    return chain.dispatchEvent(event);
                } catch (final Exception e) {
                    // handle all the exceptions here 
                    return null;
                }
            }
        });
    }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-11-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-11-01
    • 2011-11-09
    • 1970-01-01
    相关资源
    最近更新 更多