Heim >Java >javaLernprogramm >Wie vermeide ich „IllegalStateException' bei der Verwendung von Threads für Datenbankanforderungen in JavaFX?

Wie vermeide ich „IllegalStateException' bei der Verwendung von Threads für Datenbankanforderungen in JavaFX?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-12-24 19:34:11899Durchsuche

How to Avoid `IllegalStateException` When Using Threads for Database Requests in JavaFX?

Verwenden von Threads zum Ausführen von Datenbankanforderungen

In JavaFX ist es wichtig, bestimmte Threading-Regeln zu befolgen, um die Reaktionsfähigkeit und Konsistenz der Benutzeroberfläche sicherzustellen. Dazu gehört die Ausführung lang andauernder Aufgaben wie Datenbankanforderungen in Hintergrundthreads und die Aktualisierung der Benutzeroberfläche im JavaFX-Anwendungsthread.

Threading-Regeln:

  1. Regel 1: Jeder Code, der mit dem Zustand des Szenendiagramms interagiert, muss in der JavaFX-Anwendung ausgeführt werden Thread.
  2. Regel 2:Lang laufende Vorgänge sollten in Hintergrundthreads ausgeführt werden.

IllegalStateException-Problem:

Die IllegalStateException, auf die Sie gestoßen sind, liegt daran, dass Sie versuchen, die Bezeichnung „courseCodeLbl“ über einen Hintergrundthread zu aktualisieren. Verstoß gegen Regel 1.

Korrekte Implementierung:

Um Threading korrekt zu implementieren, befolgen Sie diese Schritte:

  1. Erstellen Sie eine ausführbare Implementierung, um die zu kapseln Datenbankanforderung.
  2. Verwenden Sie die Methode Platform.runLater(), um UI-Updates für zu planen JavaFX-Anwendungsthread.

Verwendung der javafx.concurrent-API:

JavaFX stellt die javafx.concurrent-API zur Vereinfachung der gleichzeitigen Programmierung und UI-Verwaltung bereit. Die Task-Klasse ist für diese API von zentraler Bedeutung und stellt einen Mechanismus für die Hintergrundverarbeitung und Aktualisierung der Benutzeroberfläche bereit.

Beispielcode:

Hier ist eine Beispiel-Controller-Klasse, die das Richtige demonstriert Verwendung von Threading und der Task-Klasse:

import javafx.concurrent.Task;
import javafx.fxml.FXML;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;

public class Controller {
    @FXML
    private Button getCourseBtn;
    @FXML
    private TextField courseId;
    @FXML
    private Label courseCodeLbl;
    private ModelController mController;

    public void getCourseNameOnClick() {
        Task<String> courseTask = new Task<>() {
            @Override
            protected String call() {
                String courseName = "";
                Course c = new Course();
                c.setCCode(Integer.valueOf(courseId.getText()));
                mController = new ModelController(c);
                try {
                    ResultSet rs = mController.getResult();
                    if (rs.next()) {
                        courseName = rs.getString(1);
                    }
                } catch (Exception e) {
                    throw new RuntimeException(e);
                }
                return courseName;
            }
        };
        courseTask.setOnSucceeded(e -> Platform.runLater(() -> courseCodeLbl.setText(courseTask.getValue())));
        new Thread(courseTask).start();
    }
}

Dieser Code kapselt die Datenbankanforderung in einer Task, die die Ausführung der Abfrage übernimmt und Aktualisieren der Benutzeroberfläche im JavaFX-Anwendungsthread. Durch die Einhaltung der JavaFX-Threading-Regeln und die Verwendung der API können Sie Datenbankanforderungen effizient ausführen und gleichzeitig die Reaktionsfähigkeit der Benutzeroberfläche beibehalten.

Das obige ist der detaillierte Inhalt vonWie vermeide ich „IllegalStateException' bei der Verwendung von Threads für Datenbankanforderungen in JavaFX?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn