ExecutorService:等待任務完成
ExecutorService 是一個高效任務執行的便捷工具,但暫停直到所有任務完成可能會很棘手。讓我們深入探討一個常見問題及其實際解決方案。
wait() 中的錯誤
引用的程式碼片段使用固定執行緒池 ExecutorService,體驗嘗試使用 es.wait() 時出現 IllegalMonitorStateException。發生這種情況是因為 wait() 旨在與特定線程同步習慣用法一起使用,而不是與 ExecutorService 一起使用。
最簡單的解決方案:invokeAll()
ExecutorService 為此目的:invokeAll()。此方法會取得可呼叫任務的集合,並行執行它們,並阻塞直到所有任務完成。使用方法如下:
ExecutorService es = Executors.newFixedThreadPool(2); List<Callable<Object>> todo = new ArrayList<>(uniquePhrases.size()); for (DataTable singleTable: uniquePhrases) { todo.add(Executors.callable(new ComputeDTask(singleTable))); } List<Future<Object>> answers = es.invokeAll(todo);
invokeAll() 傳回一個 Future 物件列表,每個物件代表一個單獨的任務。一旦所有任務完成,訪問任何 Future 的 isDone() 將傳回 true。
invokeAll() 的優點
其他方法
請記住,invokeAll() 要求您的任務實作 Callable。如果 ComputeDTask 是 Runnable,請將其包裝為程式碼片段中所示或利用 Executors.callable()。
以上是如何有效率地等待 ExecutorService 中的所有任務完成?的詳細內容。更多資訊請關注PHP中文網其他相關文章!