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中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

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

WebStorm Mac版
好用的JavaScript开发工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

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

Atom编辑器mac版下载
最流行的的开源编辑器