ObservableList抛出NullPointerException

时间:2014-07-06 04:49:17

标签: java nullpointerexception javafx-8

我正在向ObservableList中的JavaFX添加一些元素,在添加一些项目后,我开始为我添加的所有项目获取NullPointerException。根据{{​​1}},JavaDoc方法在以下时间内抛出add()

  

NullPointerException - 如果指定的元素为null且此列表   不允许空元素

但正如你在我调试时看到的那样,我的元素是非空的:

enter image description here

那么为什么我会得到这个NullPointerException

NullPointerException

Exception in thread "JavaFX Application Thread" java.lang.NullPointerException at javafx.scene.chart.XYChart$Series$1.onChanged(XYChart.java:1525) at com.sun.javafx.collections.ListListenerHelper$SingleChange.fireValueChangedEvent(ListListenerHelper.java:158) at com.sun.javafx.collections.ListListenerHelper.fireValueChangedEvent(ListListenerHelper.java:72) at javafx.collections.ObservableListBase.fireChange(ObservableListBase.java:233) at javafx.collections.ListChangeBuilder.commit(ListChangeBuilder.java:482) at javafx.collections.ListChangeBuilder.endChange(ListChangeBuilder.java:541) at javafx.collections.ObservableListBase.endChange(ObservableListBase.java:205) at javafx.collections.ModifiableObservableListBase.add(ModifiableObservableListBase.java:155) at java.util.AbstractList.add(AbstractList.java:108) at sample.Main$1.handle(Main.java:115) at javafx.animation.AnimationTimer$AnimationTimerReceiver$1.run(AnimationTimer.java:58) at javafx.animation.AnimationTimer$AnimationTimerReceiver$1.run(AnimationTimer.java:56) at java.security.AccessController.doPrivileged(Native Method) at javafx.animation.AnimationTimer$AnimationTimerReceiver.handle(AnimationTimer.java:56) at com.sun.scenario.animation.AbstractMasterTimer.timePulseImpl(AbstractMasterTimer.java:359) at com.sun.scenario.animation.AbstractMasterTimer$MainLoop.run(AbstractMasterTimer.java:269) at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:475) at com.sun.javafx.tk.quantum.QuantumToolkit.pulse(QuantumToolkit.java:460) at com.sun.javafx.tk.quantum.QuantumToolkit$13.run(QuantumToolkit.java:327) 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.access$300(WinApplication.java:39) at com.sun.glass.ui.win.WinApplication$4$1.run(WinApplication.java:112) at java.lang.Thread.run(Thread.java:745) 是我使用sample.Main$1.handle(Main.java:115)方法的地方。

修改

似乎只有当我在add()TimerTask()之类的内容中添加项目时才会发生这种情况:

AnimationTimer()

否则我没有得到这个期望!

编辑2:

好的我想我知道问题是什么,这是测试代码:

new AnimationTimer(){
            @Override
            public void handle(long now) {
                for (XYChart.Data<Double, Double> data : fullDataQueue){
                    chartData.add(data);
                }
            }
        }.start();

如果我在系列中重新添加现有数据,这似乎就会发生。它不是RT-37798错误,但我认为这也是一个错误。如果我们在@Test public void testSeriesAddInAnimator(){ // Data XYChart.Series<Double, Double> series = new XYChart.Series<>(); ConcurrentLinkedQueue<XYChart.Data<Double, Double>> fullDataQueue = new ConcurrentLinkedQueue<>(); ObservableList<XYChart.Data<Double, Double>> chartData = FXCollections.observableArrayList(); series.setData(chartData); // Start adding data final Random random = new Random(); for(int n = 0; n < 10000; ++n){ fullDataQueue.add(new XYChart.Data<>((double)n, random.nextDouble())); } new AnimationTimer(){ @Override public void handle(long now) { for (XYChart.Data<Double, Double> data : fullDataQueue){ chartData.add(data); } System.out.println("Stop!"); //stop(); -> Uncomment this and we get no exception! } }.start(); System.out.println("Done testSeriesAddInAnimator()!"); } 内对stop()方法进行评论,则会重新添加相同的数据,然后我们开始获取所有这些AnimationTimer

例外情况在NullPointerException第1525行:

XYChart.java

但是,如果我尝试删除for(int i=c.getFrom(); i<c.getTo(); i++) { getData().get(i).setSeries(Series.this); // update linkedList Pointers for data in this series if (begin == null) { begin = getData().get(i); begin.next = null; } else { if (i == 0) { getData().get(0).next = begin; begin = getData().get(0); } else { Data<X,Y> ptr = begin; for (int j = 0; j < i -1 ; j++) { ptr = ptr.next; // NPE HERE!!!!! } getData().get(i).next = ptr.next; ptr.next = getData().get(i); } } } 中的所有项目然后添加我想要的项目,我会得到与您提到的错误相关的ObservableList(RT-37798)。所以我似乎注定了,在他们解决这个错误之前我无能为力。

2 个答案:

答案 0 :(得分:1)

它看起来不是data,而是data的{​​{1}}组件之一。

我找不到匹配的源代码,但如果你看一下

null

我确信您找到了对数据组件的解除引用。

答案 1 :(得分:0)

好吧似乎在JDK 8u20 Build 21中解决了RT-37798错误。将提交我必须看到的错误如果我能得到一些回复(https://javafx-jira.kenai.com/browse/RT-37824)。

感谢您的帮助!