Swing/SingleThreadExecutor のバックアップ差分(No.1)
- バックアップ一覧
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- バックアップ を表示
- Swing/SingleThreadExecutor へ行く。
- 1 (2019-06-10 (月) 16:53:40)
- 2 (2021-02-23 (火) 18:08:00)
- 3 (2022-08-20 (土) 22:15:25)
- 4 (2024-01-05 (金) 08:21:34)
- 追加された行はこの色です。
- 削除された行はこの色です。
--- category: swing folder: SingleThreadExecutor title: SwingWorkerを一スレッドづつ順番に実行する tags: [SwingWorker, ExecutorService, JTable, JProgressBar] author: aterai pubdate: 2019-06-10T16:52:22+09:00 description: JTableのセルに配置したJProgressBarを操作するSwingWorkerタスクを一つづつ順番に実行します。 image: https://drive.google.com/uc?id=1x3PqH08NWiKXBFZl355XaqHN5fyc1zEdrg --- * 概要 [#summary] JTableのセルに配置したJProgressBarを操作するSwingWorkerタスクを一つづつ順番に実行します。 #download(https://drive.google.com/uc?id=1x3PqH08NWiKXBFZl355XaqHN5fyc1zEdrg) * サンプルコード [#sourcecode] #code(link){{ ExecutorService executor = Executors.newSingleThreadExecutor(); // ... protected final void addActionPerformed() { int key = model.getRowCount(); SwingWorker<Integer, Integer> worker = new BackgroundTask() { @Override protected void process(List<Integer> c) { if (isCancelled()) { return; } if (!isDisplayable()) { System.out.println("process: DISPOSE_ON_CLOSE"); cancel(true); executor.shutdown(); return; } c.forEach(v -> model.setValueAt(v, key, 2)); } @Override protected void done() { if (!isDisplayable()) { System.out.println("done: DISPOSE_ON_CLOSE"); cancel(true); executor.shutdown(); return; } String text; int i = -1; if (isCancelled()) { text = "Cancelled"; } else { try { i = get(); text = i >= 0 ? "Done" : "Disposed"; } catch (InterruptedException | ExecutionException ex) { text = ex.getMessage(); } } System.out.format("%s:%s(%dms)%n", key, text, i); // executor.remove(this); } }; model.addProgressValue("example", 0, worker); executor.execute(worker); } }} * 解説 [#explanation] 上記のサンプルでは、`Executors.newSingleThreadExecutor()`で作成した単一スレッド用の`executor`を使用して順番に一つづ`SwingWorker`を実行しています。 ---- - `Executors.newSingleThreadExecutor()`で生成される`ExecutorService`は、`Executors.newFixedThreadPool(1)`のものとほぼ同じ ---- - デフォルトの`SwingWorker`は、`10`個のワーカ・スレッドを同時に実行可能 -- [https://community.oracle.com/thread/1364600 Swing - Maximum number of SwingWorker objects in a Swing app?] #code{{ public abstract class SwingWorker<T, V> implements RunnableFuture<T> { /** * number of worker threads. */ private static final int MAX_WORKER_THREADS = 10; }} * 参考リンク [#reference] - [https://docs.oracle.com/javase/jp/8/docs/api/java/util/concurrent/Executors.html#newSingleThreadExecutor-- Executors#newSingleThreadExecutor() (Java Platform SE 8)] - [[JTableのセルにJProgressBarを表示 - Java Swing Tips>https://ateraimemo.com/Swing/TableCellProgressBar]] * コメント [#comment] #comment #comment