【问题标题】:JavaFX application throws Null Pointer Exception on DebianJavaFX 应用程序在 Debian 上抛出空指针异常
【发布时间】:2019-05-13 10:38:15
【问题描述】:

我正在尝试在 Debian 上启动桌面 java 应用程序。

详情如下:

  • Debian Stretch 9.9
  • openjdk-8-jdk-headless:amd64 - 8u212-b01-1~deb9u1
  • openjfx - 8u141-b14-3~deb9u1

该应用程序以前在其他 PC 上运行正常很长时间。但是在这台机器上,启动我的应用程序后,我看到空窗口(没有控件)和以下异常:

java.lang.NullPointerException
    at com.sun.javafx.sg.prism.RegionImageCache.<init>(RegionImageCache.java:71)
    at com.sun.javafx.sg.prism.NGRegion.getImageCache(NGRegion.java:467)
    at com.sun.javafx.sg.prism.NGRegion.renderBackgroundRectangle(NGRegion.java:811)
    at com.sun.javafx.sg.prism.NGRegion.renderAsRectangle(NGRegion.java:751)
    at com.sun.javafx.sg.prism.NGRegion.renderContent(NGRegion.java:572)
    at com.sun.javafx.sg.prism.NGNode.doRender(NGNode.java:2053)
    at com.sun.javafx.sg.prism.NGNode.render(NGNode.java:1945)
    at com.sun.javafx.sg.prism.NGGroup.renderContent(NGGroup.java:235)
    at com.sun.javafx.sg.prism.NGRegion.renderContent(NGRegion.java:576)
    at com.sun.javafx.sg.prism.NGNode.doRender(NGNode.java:2053)
    at com.sun.javafx.sg.prism.NGNode.render(NGNode.java:1945)
    at com.sun.javafx.sg.prism.NGGroup.renderContent(NGGroup.java:235)
    at com.sun.javafx.sg.prism.NGRegion.renderContent(NGRegion.java:576)
    at com.sun.javafx.sg.prism.NGNode.doRender(NGNode.java:2053)
    at com.sun.javafx.sg.prism.NGNode.render(NGNode.java:1945)
    at com.sun.javafx.tk.quantum.ViewPainter.doPaint(ViewPainter.java:477)
    at com.sun.javafx.tk.quantum.ViewPainter.paintImpl(ViewPainter.java:330)
    at com.sun.javafx.tk.quantum.UploadingPainter.run(UploadingPainter.java:134)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:308)
    at com.sun.javafx.tk.RenderJob.run(RenderJob.java:58)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at com.sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.run(QuantumRenderer.java:125)
    at java.lang.Thread.run(Thread.java:748)

有没有办法解决这个问题?

附言。部分应用代码

Application.launch(FXMainWindow.class);

public class FXMainWindow extends Application  {

    private ArrayList<ToggleButton> components;

    @Override
    public void start(Stage stage) throws Exception {

        stage.setTitle("App");
        BorderPane root = new BorderPane();

        //bottom
        HBox bottom = new HBox();
        root.setBottom(bottom);

        Button btnRefreshAll = new Button("some");
        HBox.setHgrow(btnRefreshAll, Priority.ALWAYS);
        btnRefreshAll.setMaxWidth(Double.MAX_VALUE);
        btnRefreshAll.setOnAction(event-> {
                new EntityStateRefresher(actions, 10, this).start();
        });
        bottom.getChildren().add(btnRefreshAll);

         .....

        Scene scene = new Scene(root, 210, 363);
        stage.setScene(scene);
        stage.show();

    }

【问题讨论】:

  • 导致问题的代码是什么?
  • @Matt 添加代码
  • 我猜,NPE 是由 javafx 渲染器线程引起的,而不是由应用程序代码引起的。另外,我提醒一下应用程序在 oracle java/javafx 上运行正常
  • 此异常似乎不是由您编码的任何内容引起的,而是 JavaFX 本身的深处出现了问题。您的 OpenJDK 8 版本包含“headless”这个词,也许这就是问题所在?

标签: java javafx debian openjfx


【解决方案1】:

安装支持 OpenGL 的视频驱动程序 (i915) 并将nouveau 列入黑名单后,问题解决了。

感谢大家的cmets

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-12-02
    • 2020-11-22
    • 2020-08-10
    • 2013-03-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多