> 데이터 베이스 > MySQL 튜토리얼 > 백그라운드 데이터베이스 스레드에서 JavaFX UI를 안전하게 업데이트하는 방법은 무엇입니까?

백그라운드 데이터베이스 스레드에서 JavaFX UI를 안전하게 업데이트하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-26 19:29:09
원래의
821명이 탐색했습니다.

How to Safely Update JavaFX UI from Background Database Threads?

스레드를 사용하여 JavaFX로 데이터베이스 요청

JavaFX는 스레드와 관련하여 두 가지 기본 규칙을 규정합니다.

  1. 모두 장면 그래프 노드 상태와의 상호 작용은 JavaFX 애플리케이션에서 실행되어야 합니다. 스레드.
  2. 장시간의 작업은 백그라운드 스레드에서 실행되어야 합니다.

예외 발생

업데이트 시도로 인해 발생한 예외입니다. JavaFX 애플리케이션이 아닌 스레드의 UI(courseCodeLbl.setText(...)) thread.

올바른 스레딩 구현

데이터베이스 요청이 별도의 스레드에서 실행되도록 하려면 다음 단계를 따르세요.

  • 실행 가능 파일 생성 클래스를 만들고 데이터베이스 요청이 포함된 run() 메서드를 구현합니다.
  • 이 클래스의 인스턴스를 스레드 생성자를 생성하고 스레드를 시작합니다.
  • Platform.runLater(Runnable r)를 사용하여 데이터베이스 결과로 UI를 업데이트합니다.

JavaFX.concurrent를 사용하여 스레딩 구현

JavaFX는 백그라운드 스레드를 관리하고 업데이트하기 위해 특별히 설계된 Task 클래스를 제공합니다. UI.

  • Task 객체를 생성하고 call() 메서드에서 데이터베이스 호출을 정의합니다.
  • updateProgress(...) 및 updateMessage(...)를 사용하여 실행 중 UI.
  • setOnSucceeded(...) 및 setOnFailed(...) 핸들러를 등록하여 결과를 처리하고 처리합니다. 오류.
  • Task.Executor(예: Executors.newCachedThreadPool)를 사용하여 작업을 호출합니다.

샘플 구현

Task<Course> courseTask = new Task<Course>() {
    @Override
    public Course call() throws Exception {
        return myDAO.getCourseByCode(courseCode);
    }
};
courseTask.setOnSucceeded(e -> {
    Course course = courseTask.getCourse();
    if (course != null) {
        courseCodeLbl.setText(course.getName());
    }
});
exec.execute(courseTask);
로그인 후 복사

이 예에서 데이터베이스 액세스는 작업에서 수행되고 UI 업데이트는 작업에서 예약됩니다. setOnSucceeded 핸들러를 사용하는 JavaFX 애플리케이션 스레드입니다. 이러한 지침을 따르면 스레드를 효과적으로 사용하여 JavaFX 애플리케이션에서 UI 응답성을 유지하면서 데이터베이스 요청을 최적화할 수 있습니다.

위 내용은 백그라운드 데이터베이스 스레드에서 JavaFX UI를 안전하게 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿