在 JavaFX 中,有两个关键规则控制线程:
您的代码显示异常,因为您正在尝试从后台线程(使用 Runnable 创建的新 Thread)修改 courseCodeLbl 标签(UI 操作)。这违反了规则 1。
要解决此问题,您应该在后台线程中执行数据库请求,然后在 JavaFX 应用程序线程上更新 UI。这可以通过以下步骤来实现:
JavaFX 提供 javafx.concurrent API 来管理并发并处理来自后台线程的 UI 更新。 Task 是此 API 中的基础类,它允许您:
遵循推荐的设计模式,数据库访问应封装在 数据访问对象 (DAO) 中 类,它不知道 UI。然后,可以使用任务在后台线程上调用 DAO 的方法。
这是按类型检索小部件的 DAO 示例:
public class WidgetDAO { public List<Widget> getWidgetsByType(String type) throws SQLException { // Database query to retrieve widgets } }
以及使用Task 和 javafx.concurrent.Executor 执行数据库操作并更新 UI:
public class MyController { private WidgetDAO widgetAccessor; private Executor exec; // Executor to execute tasks on a thread pool public void searchWidgets() { final String searchString = widgetTypeSearchField.getText(); Task<List<Widget>> widgetSearchTask = new Task<>() { @Override public List<Widget> call() throws Exception { return widgetAccessor.getWidgetsByType(searchString); } }; widgetSearchTask.setOnSucceeded(e -> { widgetTable.getItems().setAll(widgetSearchTask.getValue()); }); exec.execute(widgetSearchTask); } }
通过封装数据库访问并利用 JavaFX 的并发 API,您可以在单独的线程上执行数据库请求,同时保持 UI 响应能力。
以上是如何在 JavaFX 中安全地执行数据库请求而不阻塞 UI 线程?的详细内容。更多信息请关注PHP中文网其他相关文章!