百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Java8-parallelStream()使用

liuian 2025-01-09 14:25 18 浏览

parallelStream()

parallelStream() 是 Java 8 引入的一种方法,属于 Stream 接口的一部分。它用于提供并行处理流数据的能力,从而利用多核处理器提高性能。通过使用 parallelStream(),可以轻松实现数据的并行处理,而无需手动管理线程或并发。

基本概念

  • Stream: 是一种用于处理集合的抽象,可以对集合数据进行过滤、映射、排序等操作。
  • parallelStream(): 该方法返回一个 **并行流**,允许流中的元素被分配到多个线程中进行并行处理。

如何使用 parallelStream()

以下是使用 parallelStream() 的基本步骤和示例:

  1. 创建集合:首先,您需要一个集合(如 List、Set 等)。
  2. 调用 parallelStream():在集合上调用 parallelStream() 方法。
  3. 使用流操作:对流进行各种操作,如 map、filter、collect 等。
  4. 终止操作:使用终止操作(如 forEach、collect)来执行流的操作。

示例代码

import java.util.Arrays;
import java.util.List;

public class ParallelStreamExample {
    public static void main(String[] args) {
        List<String> names = Arrays.asList("Alice", "Bob", "Charlie", "David", "Eve");

        // 使用 parallelStream() 进行并行处理
        names.parallelStream()
             .filter(name -> name.length() > 3) // 过滤出长度大于 3 的名字
             .map(String::toUpperCase) // 将名字转换为大写
             .forEach(System.out::println); // 打印结果
    }
}


import java.util.concurrent.ForkJoinPool;

public class CustomParallelStream {
    public static void main(String[] args) {
        ForkJoinPool customThreadPool = new ForkJoinPool(4); // 创建一个具有4个线程的线程池

        customThreadPool.submit(() -> {
            List<String> names = Arrays.asList("Alice", "Bob", "Charlie", "David", "Eve");
            names.parallelStream()
                 .forEach(name -> System.out.println(name + " processed by " + Thread.currentThread().getName()));
        }).join(); // 等待任务完成
    }
}


注意事项

  • 性能: 在某些情况下,使用 parallelStream() 可以显著提高性能,尤其是在处理大量数据时。然而,对于小规模数据集,开启并行处理可能会导致性能下降,因为线程管理的开销可能超过并行处理带来的好处。
  • 如果并行里面存在查询数据库可能对数据库造成成倍压力,需要做好一定预估。
  • 无状态操作: 并行流中的操作是无状态的,确保在处理过程中不会引入共享可变状态。这意味着如果你的操作依赖于某个共享的变量,可能会导致数据不一致和错误。
  • 线程安全: 确保在使用并行流时,任何共享的可变对象都是线程安全的。例如,使用 ConcurrentHashMap 或其他线程安全的集合类来存储结果。
  • 调试: 调试并行流可能会比较困难,因为流中的操作可能在不同的线程中异步执行。


使用场景

假设有一个订单包装返回值的逻辑,订单需要处理调用物流信息、订单基础信息、商品基础信息、退货信息等,目前耗时比较高可能达到400ms了,这时你可以:创建一个IBuildHandler 接口,包含 handler 方法,如下所示:

public interface IBuildHandler {void handler(Condition condition, List<UserOrder> userOrderList);
}

然后,你可以使用并行流来处理多个处理器进行处理逻辑:

List<IBuildHandler> buildHandlers = Arrays.asList(new BuildHandlerA(), new BuildHandlerB(), new BuildHandlerC());
Request req = new Request();
List<UserOrder> userOrderList = getUserOrderList();
buildHandlers.parallelStream()
    .forEach(iBuildHandler -> iBuildHandler.handler(req.getCondition(), userOrderList));

工作原理

  • 分割任务: 当你调用 parallelStream() 时,Java 会将原始数据集合分割成多个小块(也称为任务)。这些小块将被分配给多个线程进行处理。
  • Fork/Join 框架: parallelStream() 底层使用了 Java 的 Fork/Join 框架。这个框架专门用于实现并行处理,能够有效地管理任务的分割和合并。
  • 线程池: 默认情况下,Fork/Join 框架使用一个公共的 ForkJoinPool,它的线程数量通常是 CPU 核心数的两倍。每个任务会在这个线程池中执行。

总结

parallelStream() 是 Java 8 及以上版本中一个强大的特性,允许开发者方便地实现并行数据处理。使用时要注意性能、线程安全和无状态操作等问题,以确保获得最佳的性能和正确的结果。

相关推荐

2023年最新微信小程序抓包教程(微信小程序 抓包)

声明:本公众号大部分文章来自作者日常学习笔记,部分文章经作者授权及其他公众号白名单转载。未经授权严禁转载。如需转载,请联系开百。请不要利用文章中的相关技术从事非法测试。由此产生的任何不良后果与文...

测试人员必看的软件测试面试文档(软件测试面试怎么说)

前言又到了毕业季,我们将会迎来许多需要面试的小伙伴,在这里呢笔者给从事软件测试的小伙伴准备了一份顶级的面试文档。1、什么是bug?bug由哪些字段(要素)组成?1)将在电脑系统或程序中,隐藏着的...

复活,视频号一键下载,有手就会,长期更新(2023-12-21)

视频号下载的话题,也算是流量密码了。但也是比较麻烦的问题,频频失效不说,使用方法也难以入手。今天,奶酪就来讲讲视频号下载的新方案,更关键的是,它们有手就会有用,最后一个方法万能。实测2023-12-...

新款HTTP代理抓包工具Proxyman(界面美观、功能强大)

不论是普通的前后端开发人员,还是做爬虫、逆向的爬虫工程师和安全逆向工程,必不可少会使用的一种工具就是HTTP抓包工具。说到抓包工具,脱口而出的肯定是浏览器F12开发者调试界面、Charles(青花瓷)...

使用Charles工具对手机进行HTTPS抓包

本次用到的工具:Charles、雷电模拟器。比较常用的抓包工具有fiddler和Charles,今天讲Charles如何对手机端的HTTS包进行抓包。fiddler抓包工具不做讲解,网上有很多fidd...

苹果手机下载 TikTok 旧版本安装包教程

目前苹果手机能在国内免拔卡使用的TikTok版本只有21.1.0版本,而AppStore是高于21.1.0版本,本次教程就是解决如何下载TikTok旧版本安装包。前期准备准备美区...

【0基础学爬虫】爬虫基础之抓包工具的使用

大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...

防止应用调试分析IP被扫描加固实战教程

防止应用调试分析IP被扫描加固实战教程一、概述在当今数字化时代,应用程序的安全性已成为开发者关注的焦点。特别是在应用调试过程中,保护应用的网络安全显得尤为重要。为了防止应用调试过程中IP被扫描和潜在的...

一文了解 Telerik Test Studio 测试神器

1.简介TelerikTestStudio(以下称TestStudio)是一个易于使用的自动化测试工具,可用于Web、WPF应用的界面功能测试,也可以用于API测试,以及负载和性能测试。Te...

HLS实战之Wireshark抓包分析(wireshark抓包总结)

0.引言Wireshark(前称Ethereal)是一个网络封包分析软件。网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。Wireshark使用WinPCAP作为接口,直接...

信息安全之HTTPS协议详解(加密方式、证书原理、中间人攻击 )

HTTPS协议详解(加密方式、证书原理、中间人攻击)HTTPS协议的加密方式有哪些?HTTPS证书的原理是什么?如何防止中间人攻击?一:HTTPS基本介绍:1.HTTPS是什么:HTTPS也是一个...

Fiddler 怎么抓取手机APP:抖音、小程序、小红书数据接口

使用Fiddler抓取移动应用程序(APP)的数据接口需要进行以下步骤:首先,确保手机与计算机连接在同一网络下。在计算机上安装Fiddler工具,并打开它。将手机的代理设置为Fiddler代理。具体方...

python爬虫教程:教你通过 Fiddler 进行手机抓包

今天要说说怎么在我们的手机抓包有时候我们想对请求的数据或者响应的数据进行篡改怎么做呢?我们经常在用的手机手机里面的数据怎么对它抓包呢?那么...接下来就是学习python的正确姿势我们要用到一款强...

Fiddler入门教程全家桶,建议收藏

学习Fiddler工具之前,我们先了解一下Fiddler工具的特点,Fiddler能做什么?如何使用Fidder捕获数据包、修改请求、模拟客户端向服务端发送请求、实施越权的安全性测试等相关知识。本章节...

fiddler如何抓取https请求实现手机抓包(100%成功解决)

一、HTTP协议和HTTPS协议。(1)HTTPS协议=HTTP协议+SSL协议,默认端口:443(2)HTTP协议(HyperTextTransferProtocol):超文本传输协议。默认...