为什么我在运行时但未在调试模式下获得空指针异常

时间:2016-06-26 19:12:01

标签: java nullpointerexception threadpool

我有一个客户端服务器应用程序。消息正在应用程序中来回处理。

我怀疑某些事情没有足够的时间来回应和/或它没有及时创建。

代码的这个特定区域正在处理它在客户端中设置数据的消息。处理消息的方式是通过命令。这些命令被放入线程池执行器中。我在运行时遇到以下异常。但是,当我调试并进入execute方法然后跨过每一行时,我从未遇到异常。这使得调试非常困难。

任何调试建议都会受到高度赞赏,因为我是线程管理的新手(希望它与线程无关)。

Exception in thread "pool-1-thread-1" java.lang.NullPointerException
at Client.Commands.DisplayProjects.execute(DisplayProjects.java:47)
at Client.Commands.ClientCommand.run(ClientCommand.java:31)
at Client.Commands.ProcessData.execute(ProcessData.java:24)
at Client.Commands.ClientCommand.run(ClientCommand.java:31)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)

以下是执行方法:

    @Override
public void execute(Client client) {
            /* Create and display the form */
    java.awt.EventQueue.invokeLater(() -> {
        new SplashScreen(client).setVisible(true);
    });
    System.out.println("SplashScreen is null"+client.splashscreen==null);
    client.splashscreen.setProjects(projects);
}

以下是setProjects方法:

    public void setProjects(ArrayList<String> projects){
    DefaultTableModel model = new DefaultTableModel();
    int row = 0;model.setRowCount(0);
    model.addColumn("Application", new Object[0]);
    model.addColumn("Description", new Object[0]);
    Iterator<String> iterator = projects.iterator();
    while(iterator.hasNext()){
        String name = iterator.next();
        String[] projectRow = new String[2];
        projectRow[0] = iterator.next();projectRow[1]="";
        model.addRow(projectRow);
    }
    ProjectTable.setModel(model);

}

0 个答案:

没有答案