在 JavaFX TextField 中输入文本会冻结应用程序

Entering text into JavaFX TextField freezes application

在我们的 JavaFX 应用程序中,不同的客户在 TextField 中输入文本时或多或少偶尔会遇到以下错误。结果,渲染框架似乎 运行 进入了一个无限循环,在这个循环中,以下错误被反复打印到系统控制台中。从那里开始,应用程序完全冻结,必须终止并重新启动,这对那些客户来说是一个完全的障碍。

这里不涉及线程问题(Fx和工作线程)。

错误出现在 Windows 7 和 10,Java 1.8.0_171,但我记得它也发生在以前的 Java 版本中:

Exception in thread "JavaFX Application Thread"
java.lang.ArrayIndexOutOfBoundsException: -1
            at java.util.ArrayList.elementData(Unknown Source)
            at java.util.ArrayList.get(Unknown Source)
            at com.sun.javafx.collections.ObservableListWrapper.get(ObservableListWrapper.java:89)
            at com.sun.javafx.collections.VetoableListDecorator.get(VetoableListDecorator.java:306)
            at javafx.scene.Parent.updateCachedBounds(Parent.java:1591)
            at javafx.scene.Parent.recomputeBounds(Parent.java:1535)
            at javafx.scene.Parent.impl_computeGeomBounds(Parent.java:1388)
            at javafx.scene.layout.Region.impl_computeGeomBounds(Region.java:3078)
            at javafx.scene.Node.updateGeomBounds(Node.java:3579)
            at javafx.scene.Node.getGeomBounds(Node.java:3532)
            at javafx.scene.Node.computeLocalBounds(Node.java:3595)
            at javafx.scene.Node.updateLocalBounds(Node.java:3625)
            at javafx.scene.Node.getLocalBounds(Node.java:3486)
            at javafx.scene.Node.updateTxBounds(Node.java:3643)
            at javafx.scene.Node.getTransformedBounds(Node.java:3426)
            at javafx.scene.Node.updateBounds(Node.java:559)
            at javafx.scene.Parent.updateBounds(Parent.java:1719)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Parent.updateBounds(Parent.java:1717)
            at javafx.scene.Scene$ScenePulseListener.pulse(Scene.java:2404)
            at com.sun.javafx.tk.Toolkit.lambda$runPulse(Toolkit.java:398)
            at java.security.AccessController.doPrivileged(Native Method)
            at com.sun.javafx.tk.Toolkit.runPulse(Toolkit.java:397)
            at com.sun.javafx.tk.Toolkit.firePulse(Toolkit.java:424)
            at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:518)
            at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:498)
            at com.sun.javafx.tk.quantum.QuantumToolkit.pulseFromQueue(QuantumToolkit.java:491)
            at com.sun.javafx.tk.quantum.QuantumToolkit.lambda$runToolkit3(QuantumToolkit.java:319)
            at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
            at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
            at com.sun.glass.ui.win.WinApplication.lambda$null7(WinApplication.java:177)
            at java.lang.Thread.run(Unknown Source)

对我来说,这显然是 Parent.java:1591 中的一个编程错误,因为 remainingDirtyNodes 似乎与 dirtyNodes 列表不同步,但没有对 dirtyNodes 进行边界检查,导致 ArrayIndexOutOfBoundsException。

有什么解决方法吗?

谢谢,彼得

PS:除此之外,JavaFX 似乎 运行 非常稳定并且使用起来很有趣。

这是一个错误,与 "removing a Node from the scene graph"

有关

它仍然没有修复,计划在 Open JFX 11 中发布。我不确定你什么时候可以发布,因为 JavaFX 正在从 JDK 中分离出来,这个问题已经解决了开业两年了

该票证包含一个最小的示例,因此您可能希望的最好结果是找到您如何操作场景图和解决问题的相关性。

参见:https://bugs.openjdk.java.net/browse/JDK-8163078