搜索
首页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无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器