「Java Swing 非同期処理の結果をGUIに表示する」の版間の差分
ナビゲーションに移動
検索に移動
(ページの作成:「==Java Swing 非同期処理の結果をGUIに表示する== [Java]{{category 並行処理}} *イベントディスパッチスレッド ===SwingWorkerを利用する=…」) |
|||
| 1行目: | 1行目: | ||
==Java Swing 非同期処理の結果をGUIに表示する== | ==Java Swing 非同期処理の結果をGUIに表示する== | ||
| − | [Java]{{category 並行処理}} | + | [[Java]]{{category 並行処理}} |
*イベントディスパッチスレッド | *イベントディスパッチスレッド | ||
===SwingWorkerを利用する=== | ===SwingWorkerを利用する=== | ||
| 9行目: | 9行目: | ||
LogAnalyzeWorker worker = new LogAnalyzeWorker(txtOut, logs); // txtOut : JTextArea | LogAnalyzeWorker worker = new LogAnalyzeWorker(txtOut, logs); // txtOut : JTextArea | ||
worker.execute(); | worker.execute(); | ||
| − | List | + | List<String> result = worker.get(); |
====実行例 ==== | ====実行例 ==== | ||
| − | public static class LogAnalyzeWorker extends SwingWorker | + | public static class LogAnalyzeWorker extends SwingWorker<List<String>, String> { |
private File[] logs; | private File[] logs; | ||
private JTextArea txtOut; | private JTextArea txtOut; | ||
| 21行目: | 21行目: | ||
@Override | @Override | ||
| − | protected List | + | protected List<String> doInBackground() throws Exception { |
| − | List | + | List<String> result = new ArrayList<String>(); |
for (File log : logs) { | for (File log : logs) { | ||
publish(log.getName()); // process() で取得できる処理状態の情報を返す | publish(log.getName()); // process() で取得できる処理状態の情報を返す | ||
| 36行目: | 36行目: | ||
@Override | @Override | ||
| − | protected void process(List | + | protected void process(List<String> chunks) { |
// publish() で設定した内容がリストで取得できるので、GUIに書き出す | // publish() で設定した内容がリストで取得できるので、GUIに書き出す | ||
for (String logout : chunks) { | for (String logout : chunks) { | ||
2020年2月15日 (土) 08:03時点における版
Java Swing 非同期処理の結果をGUIに表示する
- イベントディスパッチスレッド
SwingWorkerを利用する
呼出例
- バッググラウンドで複数のログファイルを処理するシナリオ
File[] logs = chooser.getSelectedFiles(); LogAnalyzeWorker worker = new LogAnalyzeWorker(txtOut, logs); // txtOut : JTextArea worker.execute(); List<String> result = worker.get();
実行例
public static class LogAnalyzeWorker extends SwingWorker<List<String>, String> {
private File[] logs;
private JTextArea txtOut;
public LogAnalyzeWorker(JTextArea txtOut, File[] logs) {
this.logs = logs;
this.txtOut = txtOut; // 結果表示先
}
@Override
protected List<String> doInBackground() throws Exception {
List<String> result = new ArrayList<String>();
for (File log : logs) {
publish(log.getName()); // process() で取得できる処理状態の情報を返す
result.add(log.getName());
// 時間がかかる処理本体
LogAnalyzer analyzer = new AccessLogAnalyzer();
analyzer.analyze(log);
}
// get() で取得できる結果を返す
return result;
}
@Override
protected void process(List<String> chunks) {
// publish() で設定した内容がリストで取得できるので、GUIに書き出す
for (String logout : chunks) {
txtOut.append(logout + "\n");
}
}
}
© 2006 矢木浩人