-2

我知道,这个问题已经得到了足够多的回答,但甚至没有一个解决方案适合我的问题。

案子:

我想将 1:n 文件导入数据库。到目前为止,一切都很好。对于每个文件,ProgressIndicator 应重置进度值。是的,确实如此。在将我的东西导入数据库时​​,GUI 似乎“卡住”了,直到下一个文件导入开始。

我的问题:

值会重置,但 ProgressIndicator 不会。但是值正在正确更新。 System.out.println(progressIndicator.getProgress());显示更新的结果,直到它达到 1.0。在导入完成之前,它会直接跳到 100% 并且永远不会重置..通过有更多的导入,并且进度不断更新为正确的值。进度达到 1.0 = 100% 后,下一次导入开始。我的错误在哪里?

ProgressUpdater 类:

public void activateBind(ReadOnlyDoubleProperty binding) {
    if (pg != null) {
        pg.progressProperty().unbind();
        pg.progressProperty().bind(binding);
    }
}

请注意,所有使用的类都会为每个文件导入进行初始化。PS:是的,我在代码中拼错了“ProgressIndicator”。

控制器类:

@FXML
ProgressIndicator progessIndicator;

ImportTask task = new ImportTask(dbConnector, insertStatements, this);
final ProgressUpdater pgup = new ProgressUpdater(progessIndicator, dbConnector.getPercentVal());
pgup.activateBind(task.progressProperty());
new ImportThread(task, counter);

导入任务类:

@Override
protected Void call() throws Exception {
    for (int i = 0; i < insertStatements.size(); i++) {
        dbC.executeInsert(insertStatements.get(i));
        updateProgress(dbC.getCurrent(), dbC.getEnd());
    }
    mc.executeImport();
    return null;
}

ImportThread 类从 Thread 扩展而来:

public ImportThread(Task task, int d) {
    super(task, "Import " + d);
    setDaemon(true);
    Platform.runLater(new Runnable() {

        @Override
        public void run() {
            start();
            try {
                join();
            } catch (InterruptedException e) {
                System.out.println("JOIN ERROR");
                e.printStackTrace();
            }
        }
    });
}

提前感谢您的帮助。

4

1 回答 1

1

出于某种原因,您故意强制 UI 线程等待您的后台任务完成,方法是将调用包装join()在对Platform.runLater(). 因此,UI 线程在任务完成之前不能做任何其他事情(例如渲染进度指示器)。

如果您希望线程在创建时立即启动(这不是一个好主意,tbh),只需start()在构造函数中调用:

public ImportThread(Task task, int d) {
    super(task, "Import " + d);
    setDaemon(true);
    start();
}

没有明显的理由Thread.start()需要在 FX 应用线程上执行,所以这里不需要 a Platform.runLater()

于 2017-10-25T17:10:16.197 回答