Java中学习Lambda表达式和stream中parallel并行方法

Java中学习Lambda表达式和stream中parallel并行方法

  • 一、介绍
    • 二、整体代码


一、介绍

Lambda表达式是Java中一种方便的函数式编程风格,可以在集合操作中大大简化代码。而parallel()方法则是Java 8中引入的并发处理方法,可以让集合操作更快速高效。下面我们来学习一下如何使用parallel()方法来提升集合操作的效率。

首先,我们创建一个包含一百万个随机字符串的ArrayList:

ArrayList<String> list = new ArrayList<>();
for (int i = 0; i < 1000000; i++) {
    list.add(RandomUtil.randomString(RandomUtil.BASE_CHAR, 6));
}

接下来,我们使用Lambda表达式和stream API来筛选出带有字母"s"的字符串,并比较使用parallel()方法和不使用parallel()方法的效率差异:

// 串行处理
long firstStartTime = System.currentTimeMillis();
List<String> slowCollect = list.stream()
        .filter(s -> s.contains("s"))
        .collect(Collectors.toList());
long firstEndTime = System.currentTimeMillis();
log.info("计算耗时" + (firstEndTime - firstStartTime));

// 并行处理
long secondStartTime = System.currentTimeMillis();
List<String> fastCollect = list.stream()
        .parallel() // 并发处理
        .filter(s -> s.contains("s"))
        .collect(Collectors.toList());
long secondEndTime = System.currentTimeMillis();
log.info("并发处理计算耗时" + (secondEndTime - secondStartTime));

通过以上代码,我们可以看到,在处理一百万个随机字符串时,使用parallel()方法可以显著提升处理效率。这是因为parallel()方法可以利用多线程并行处理集合中的元素,从而加快处理速度。

需要注意的是,并发处理并不是在所有情况下都会比串行处理更快,有时候还会带来额外的性能开销。因此,在实际应用中,需要根据具体情况来选择是否使用parallel()方法来优化集合操作。

二、整体代码

    void test() {
        ArrayList<String> list = new ArrayList<>();
        //录入一百万个随机字符串
        for (int i = 0; i < 1000000; i++) {
//            list.add(IdUtil.simpleUUID().substring(0,6));
            /**
             * randomString方法的
             * 第一个参数是字符集,比如
             * RandomUtil.BASE_CHAR_LOWER表示小写字母,
             * RandomUtil.BASE_CHAR_UPPER表示大写字母,
             * RandomUtil.BASE_CHAR_SIMPLE表示大小写字母的组合。
             * 第二个参数是生成字符串的长度。
             */
            list.add(RandomUtil.randomString(RandomUtil.BASE_CHAR, 6));
        }

        /**
         * 筛选字符串中带有s的字符串
         */
        //开始时间
        long firstStartTime = System.currentTimeMillis();
        List<String> slowCollect = list.stream()
                .filter(s -> s.contains("s"))
                .collect(Collectors.toList());
        //结束时间
        long firstEndTime = System.currentTimeMillis();
        log.info("计算耗时" + (firstEndTime - firstStartTime));


        //开始时间
        long secondStartTime = System.currentTimeMillis();
        List<String> fastCollect = list.stream()
                .parallel()//并发处理
                .filter(s -> s.contains("s"))
                .collect(Collectors.toList());
        //结束时间
        long secondEndTime = System.currentTimeMillis();
        log.info("并发处理计算耗时" + (secondEndTime - secondStartTime));
    }

在这里插入图片描述


  • 每一次挑战都是成长的契机,勇敢面对,你会变得更强大。
  • 坚持不懈的努力是成功的基石,只要你不放弃,终究会迎来辉煌的时刻。
  • 人生的路上总会有坎坷与挫折,但只要心怀希望,努力前行,总会找到光明的出口。
  • 成功不是偶然的,它是你不断努力、持之以恒的结果,相信自己,你就已经成功了一半。
  • 失败并不可怕,可怕的是放弃追求梦想的勇气,只要坚持不懈,终会收获成功的喜悦。
  • 每一次跌倒都是为了更高的飞跃,不要因为失败而气馁,而是从中吸取经验,继续前行。
  • 拥有梦想是一种幸福,追求梦想是一种勇气,坚持梦想是一种智慧,实现梦想是一种成功。
  • 生活不会向你让步,只有努力奋斗,才能赢得属于自己的辉煌人生。
  • 不要因为困难而放弃,因为坚持过后,成功的喜悦会让你感受到生命的价值。
  • 无论何时何地,都要保持一颗不屈不挠的心,相信自己,你一定能够创造奇迹。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/535378.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

qt进阶2:windows下可执行程序崩溃生成dmp,定位崩溃问题。

系列文章目录 文章目录 系列文章目录前言一、dmp文件生成二、使用步骤1.代码案例2.运行截图 前言 qt编译的可执行程序在windows下崩溃可生成dmp文件&#xff0c;用于调试定位崩溃原因。 一、dmp文件生成 略 二、使用步骤 1.代码案例 代码如下&#xff08;示例&#xff09;&…

Doodle Jump — 使用FlutterFlame开发游戏真不错!

前言 最近网上冲浪的时候&#xff0c;我偶然发现了一个国外的游戏网站&#xff0c;里面聚集了各种有趣的小游戏&#xff0c;类似于国内的4399。在浏览时&#xff0c;我遇到了一款经典的小游戏&#xff1a;Doodle Jump。上一次玩还是在上小学的时候&#xff0c;那时候父母在厨房…

2024.4.11

1.思维导图 2.指针形式验证大小端存储 #include<myhead.h>int main(int argc, const char *argv[]) {int num 0x12345678;char* ptr (char *)&num;if(*ptr 0x12){printf("big endian\n");}else if(*ptr 0x78){printf("little endian\n");}r…

LangChain-10 Agents langchainhub 共享的提示词Prompt

LangChainHub 的思路真的很好&#xff0c;通过Hub的方式将Prompt 共享起来&#xff0c;大家可以通过很方便的手段&#xff0c;短短的几行代码就可以使用共享的Prompt。 我个人非常看好这个项目。 官方推荐使用LangChainHub&#xff0c;但是它在GitHub已经一年没有更新了&#x…

Linux函数学习 epoll

1、Linux epoll函数 1.1、创建epoll实例 int epoll_create1(int flag); 返回值&#xff1a;-1 失败&#xff0c;非负数 成功 flag &#xff1a;默认传入0 1.2、管理epoll对象 int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event); epfd &#xff1a;e…

.a和.so库文件是什么?

我们在编译开源代码后&#xff0c;通常会生成.a和.so这两个库文件&#xff0c;这两个文件有什么区别&#xff1f;又如何使用&#xff1f; 在 Linux 中&#xff0c;.a 和 .so 文件都是库文件&#xff0c;但它们有一些区别&#xff1a; 静态库文件&#xff08;.a&#xff09;&am…

PaddleDetection 项目使用说明

PaddleDetection 项目使用说明 PaddleDetection 项目使用说明数据集处理相关模块环境搭建 PaddleDetection 项目使用说明 https://github.com/PaddlePaddle/PaddleDetection/blob/release/2.7/configs/ppyoloe/README_cn.md 自己项目&#xff1a; https://download.csdn.net/d…

融中财经专访 | 欧科云链:从跟随行业到引领行业

导读 THECAPITAL 新行业中的经验“老兵”。 本文4089字&#xff0c;约5.8分钟 作者 | 吕敬之 编辑 | 吾人 来源 | 融中财经 &#xff08;ID&#xff1a;thecapital&#xff09; 一个新兴行业从发展到成熟需要几个必要的推手&#xff1a;人才、产品、制度。 Web3.0&…

每天五分钟深度学习:逻辑回归算法的损失函数和代价函数是什么?

本文重点 前面已经学习了逻辑回归的假设函数,训练出模型的关键就是学习出参数w和b,要想学习出这两个参数,此时需要最小化逻辑回归的代价函数才可以训练出w和b。那么本节课我们将学习逻辑回归算法的代价函数是什么? 为什么不能平方差损失函数 线性回归的代价函数我们使用…

Hystrix:实现分布式系统的延迟处理和容错保护机制

文章目录 一、Hystrix的概念与作用1.1、资源隔离1.2、熔断器模式1.3、命令模式1.4、监控和报警 二、Hystrix的使用方法三、总结 一、Hystrix的概念与作用 Hystrix是Netflix开源的一个库&#xff0c;用于处理分布式系统中的延迟和容错。它通过在服务调用之间添加保护机制&#…

Leetcode刷题-字符串详细总结(Java)

字符串 字符串可能在算法处理上面和数组是类似的&#xff0c;但是String和数组的数据结构还是有一些不一样的 1、反转字符串 344. 反转字符串 - 力扣&#xff08;LeetCode&#xff09; 双指针的经典应用&#xff0c;两个指针同时向中间移动 public void reverseString(char[…

VMware启动显示“打开虚拟机时出错: 获取该虚拟机的所有权失败”

提示框&#xff08;忘截图了&#xff09;里提示目录C:\Users\mosep\Documents\Virtual Machines\VM-Win10 x64\中的某个文件&#xff08;在我这里好像是VM-Win10 x64.vmx&#xff0c;VM-Win10 x64是我给虚拟机取的名字&#xff09;在被使用中。 找到这个目录&#xff0c;删除.…

Python+Selenium+Unittest 之Unittest4(断言)

在unittest框架的TestCase类也提供了多种断言的方法。 断言常用方法 断言方法检查内容assertEqual(a,b)判断a是否等于b&#xff08;判断两个是不是同一个值&#xff09;assertNotEqual(a, b)判断a是否不等于b&#xff08;判断两个是不是同一个值&#xff09;assertTrue(a)判断a…

RAG应用开发实战(01)-RAG应用框架和解析器

1 开源解析和拆分文档 第三方的工具去对文件解析拆分&#xff0c;去将我们的文件内容给提取出来&#xff0c;并将我们的文档内容去拆分成一个小的chunk。常见的PDF word mark down, JSON、HTML。都可以有很好的一些模块去把这些文件去进行一个东西去提取。 优势 支持丰富的文…

[RK3399 Linux] 移植Linux 5.2.8内核详解

背景是在RK3399上面移植Rockchip官方提供的u-boot 2017.09 一、linux内核 1.1 源码下载 内核源码下载地址为:《https://www.kernel.org/》: 也可以到内核镜像网址下载https://mirrors.edge.kernel.org/pub/linux/kernel/,这里下载速度更快。 如果下载速度太慢,无法下载,…

2024.4.12蚂蚁庄园今日答案:豆腐在烹调时容易碎有什么办法可以避免?

原文来源&#xff1a;蚂蚁庄园今日答案 - 词令 蚂蚁庄园是一款爱心公益游戏&#xff0c;用户可以通过喂养小鸡&#xff0c;产生鸡蛋&#xff0c;并通过捐赠鸡蛋参与公益项目。用户每日完成答题就可以领取鸡饲料&#xff0c;使用鸡饲料喂鸡之后&#xff0c;会可以获得鸡蛋&…

【数学建模】机器人避障问题

已知&#xff1a; 正方形5的左下顶点坐标 ( 80 , 60 ) (80,60) (80,60)&#xff0c;边长 150 150 150机器人与障碍物的距离至少超过 10 10 10个单位规定机器人的行走路径由直线段和圆弧组成&#xff0c;其中圆弧是机器人转弯路径。机器人不能折线转弯&#xff0c;转弯路径由与…

【C++算法】线性DP详解:数字三角形、最长上升子序列、最长公共子序列、最长公共子串、字符串编辑距离

文章目录 1&#xff09;数字三角形1&#xff1a;顺推2&#xff1a;逆推 2&#xff09;最长上升子序列1&#xff1a;线性DP做法2&#xff1a;二分优化 3&#xff09;最长公共子序列4&#xff09;最长公共子串5&#xff09;字符串编辑距离 1&#xff09;数字三角形 1&#xff1a…

git修改本地提交历史邮箱地址

1、Git&#xff08;Git&#xff09; 2、修改Git本地提交历史中的邮箱地址 使用 git rebase 命令进行交互式重置。 具体步骤如下&#xff1a;&#xff08;https://git-scm.com/docs/git-rebase&#xff09; 1、查看提交历史&#xff1a; 使用 git log 命令列出提交历史&#x…

HCIE考试第三题:业务容器化及割接

文章目录 业务容器化及割接题目和做题步骤如下3.1业务容器化及割接3.1创建CCE集群solo3.2创建NAT网关3.2.1申请EIP3.2.2创建NAT网关3.2.3添加SNAT规则3.3创建节点池3.3.1 创建namespace3.3.2创建节点池3.4 安装命令行工具kubectl3.4.1上传kubectl3.4.2上传kubeconfig配置文件3.…