搜尋
首頁Javajava教程Java 8並行流可以使用自訂執行緒池進行任務隔離嗎?

Can Java 8 Parallel Streams Use Custom Thread Pools for Task Isolation?

Java 8 並行流的自訂執行緒池

在Java 8 並行流領域,出現了一個問題:是否可以使用針對特定任務的自訂執行緒池?儘管進行了廣泛的搜索,但許多開發人員仍無法實現此功能。

考慮需要並行流的多執行緒伺服器應用程式。然而,為了保持分隔並防止一個模組的任務阻塞其他模組,每個模組都需要不同的執行緒池。

為了說明該問題,請考慮以下範例:

ExecutorService es = Executors.newCachedThreadPool();

es.execute(() -> runTask(1000)); // incorrect task
es.execute(() -> runTask(0));
es.execute(() -> runTask(0));
es.execute(() -> runTask(0));
es.execute(() -> runTask(0));
es.execute(() -> runTask(0));

在此人為的範例,CPU 密集型任務是使用 Executors.newCachedThreadPool() 並行執行的。第一個任務是透過模擬線程睡眠故意減慢的。結果,其他任務陷入困境,等待完成。這演示了一個模組中的緩慢任務如何阻礙其他模組中的任務。

但是,有一個巧妙的解決方案可以解決這一困境:在特定的 fork-join 池中將並行操作作為任務執行。透過這樣做,它們與其他並行流操作使用的公共 fork-join 池保持隔離。

final int parallelism = 4;
ForkJoinPool forkJoinPool = null;
try {
    forkJoinPool = new ForkJoinPool(parallelism);
    final List<integer> primes = forkJoinPool.submit(() ->
        // Parallel task here, for example
        IntStream.range(1, 1_000_000).parallel()
                .filter(PrimesPrint::isPrime)
                .boxed().collect(Collectors.toList())
    ).get();
    System.out.println(primes);
} catch (InterruptedException | ExecutionException e) {
    throw new RuntimeException(e);
} finally {
    if (forkJoinPool != null) {
        forkJoinPool.shutdown();
    }
}</integer>

此技術利用 ForkJoinTask.fork(),它指定當前任務是否在fork-join 池,非同步執行應該發生在該池中。否則,將使用 ForkJoinPool.commonPool()。

透過利用這種方法,您可以在多執行緒應用程式中的各個模組中安全地使用並行流,而不會影響效能或任務劃分。

以上是Java 8並行流可以使用自訂執行緒池進行任務隔離嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱工具

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。