Java8新特性 - Stream

一、特性

Java 8引入的Stream API为集合(Collections)提供了一种声明式的处理方式,支持丰富的操作,包括筛选、映射、归约等。以下是一些Stream的主要功能和使用方式的案例:

  1. 创建Stream:
List<String> list = Arrays.asList("apple", "banana", "orange");
Stream<String> streamFromCollection = list.stream();
Stream<String> streamFromValues = Stream.of("apple", "banana", "orange");
  1. 过滤(Filter):
List<String> filteredList = list.stream().filter(fruit -> fruit.startsWith("a")).collect(Collectors.toList());
System.out.println("Filtered List: " + filteredList);
  1. 映射(Map):
List<String> uppercasedList = list.stream().map(String::toUpperCase).collect(Collectors.toList());
System.out.println("Uppercased List: " + uppercasedList);
  1. 平坦化(FlatMap):
List<List<String>> nestedList = Arrays.asList(Arrays.asList("apple", "banana"),Arrays.asList("orange", "grape")
);List<String> flatMapList = nestedList.stream().flatMap(Collection::stream).collect(Collectors.toList());
// FlatMap List: [apple, banana, orange, grape]
System.out.println("FlatMap List: " + flatMapList);
  1. 筛选和截断(Limit和Skip):
List<String> limitedList = list.stream().limit(2).collect(Collectors.toList());List<String> skippedList = list.stream().skip(1).collect(Collectors.toList());System.out.println("Limited List: " + limitedList);
System.out.println("Skipped List: " + skippedList);
  1. 排序(Sorted):
List<String> sortedList = list.stream().sorted().collect(Collectors.toList());
System.out.println("Sorted List: " + sortedList);
  1. 匹配(anyMatch、allMatch、noneMatch):
boolean anyStartsWithA = list.stream().anyMatch(fruit -> fruit.startsWith("a"));
boolean allStartWithA = list.stream().allMatch(fruit -> fruit.startsWith("a"));
boolean noneStartsWithZ = list.stream().noneMatch(fruit -> fruit.startsWith("z"));System.out.println("Any starts with 'a': " + anyStartsWithA);
System.out.println("All start with 'a': " + allStartWithA);
System.out.println("None starts with 'z': " + noneStartsWithZ);
  1. 归约(Reduce):
    将字符串列表中的所有元素连接成一个单一的字符串,以逗号和空格分隔。
Optional<String> concatenated = list.stream().reduce((s1, s2) -> s1 + ", " + s2);
concatenated.ifPresent(result -> System.out.println("Concatenated: " + result));
  1. 收集(Collect):
List<String> collectedList = list.stream().filter(fruit -> fruit.length() > 5).collect(Collectors.toList());Set<String> collectedSet = list.stream().filter(fruit -> fruit.length() > 5).collect(Collectors.toSet());String joinedString = list.stream().collect(Collectors.joining(", "));System.out.println("Collected List: " + collectedList);
System.out.println("Collected Set: " + collectedSet);
System.out.println("Joined String: " + joinedString);

这些例子展示了Stream API的一些常见用法。Stream 提供了丰富的操作,使得对集合进行处理变得更加简洁和表达力强。

二、解决问题

Stream 是 Java 8 引入的一种处理集合(Collections)数据的新方式,它主要解决了在集合上进行复杂操作时代码的繁琐性、可读性差和性能问题。以下是一些 Stream 的优点和解决的问题,并附带一些案例:

  1. 声明式编程:

    • 问题:传统方式对集合的操作通常需要使用迭代器或者显式的循环,导致代码冗长且难以理解。
    • 解决方案:Stream 提供了声明式的编程方式,可以更清晰地表达对集合的操作。
    List<String> fruits = Arrays.asList("apple", "banana", "orange");
    fruits.stream().filter(s -> s.startsWith("a")).forEach(System.out::println);
    
  2. 链式调用:

    • 问题:在传统方式中,对集合的多次操作需要多次迭代或多次循环,效率低下。
    • 解决方案:Stream 支持链式调用,可以在一次迭代中执行多个操作。
    List<String> result = fruits.stream().filter(s -> s.startsWith("a")).map(String::toUpperCase).collect(Collectors.toList());
    
  3. 不可变性和延迟执行:

    • 问题:传统方式中的集合操作可能会改变原集合,或者在每一步都立即执行。
    • 解决方案:Stream 操作不会改变原集合,而是返回一个新的 Stream,并且操作是延迟执行的。
    List<String> result = fruits.stream().filter(s -> s.startsWith("a")).map(String::toUpperCase).collect(Collectors.toList());
    
  4. 并行处理:

    • 问题:在传统方式中,手动编写并行化代码可能会很困难。
    • 解决方案:Stream 提供了简便的方法来实现并行处理,提高了性能。
    long count = fruits.parallelStream().filter(s -> s.startsWith("a")).count();
    
  5. 简化聚合操作:

    • 问题:传统方式中聚合操作(如求和、平均值)需要编写显式的循环代码。
    • 解决方案:Stream 提供了内置的聚合操作,简化了这类操作。
    double averageLength = fruits.stream().mapToInt(String::length).average().orElse(0);
    

这些案例展示了 Stream 如何解决传统集合操作中的一些问题,并提供了更简洁、清晰和高效的处理方式。通过使用 Stream,代码变得更加表达力强,可读性更高,并且在某些情况下能够更容易地实现并行化。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java语言概述及保姆级入门教程(JDK 17版本)

笔记来自尚硅谷老师-康老师 学习教程&#xff1a;https://www.bilibili.com/video/BV1PY411e7J6/?spm_id_from333.337.search-card.all.click 1、Java基础全程脉络图 1.1 本章专题与脉络 2. 抽丝剥茧话Java 2.1 当前大学生就业形势 麦可思研究院发布了《2022年中国大学生就业…

TCP 和UDP 到底有啥区别

TCP&#xff08;传输控制协议&#xff09;和UDP&#xff08;用户数据报协议&#xff09;是互联网上常用的两种传输层协议&#xff0c;它们在数据传输方式和特性上有显著的区别。下面是TCP和UDP的主要区别&#xff1a; 连接性: TCP 是一种面向连接的协议。在数据传输前&#xf…

C#图像处理OpenCV开发指南(CVStar,09)——边缘识别之Scharr算法的实例代码

1 边缘识别之Scharr算法 算法文章很多&#xff0c;不再论述。 1.1 函数原型 void Cv2.Scharr(src,dst,ddepth,dx,dy,scale,delta,borderType&#xff09; 1.2 参数说明 src 代表原始图像。dst 代表目标图像。ddepth 代表输出图像的深度。CV_16Sdx 代表x方向上的求导阶数…

uniApp应用软件在运行时,不符合华为应用市场审核标准。解决方案合集!

&#xff08;暂时用不到的也建议收藏一下&#xff0c;因为文章持续更新中&#xff09; 最新更改时间&#xff1a;20023-12-10 第一次做App应用开发相信大家一定都遇到过华为应用市场审核的“驳回”&#xff01; 有些问题一看就明白可以立马修改&#xff0c;而有一些问题修改意…

Dubbo入门直接上手,结合微服务详解

Dubbo 高性能、轻量级的 Java RPC 框架 RPC&#xff1a; Remote Procedure Call 远程过程调用&#xff0c;简单来说就是它允许一个计算机程序通过网络请求调用另一个计算机上的程序&#xff0c;就像本地调用一样。有非常多的协议和技术来都实现了RPC的过程&#xff0c;比如&a…

Elasticsearch 8.9 refresh刷Es缓冲区的数据到Lucene,更新segemnt,使数据可见

一、相关API的handler1、接受HTTP请求的hander(RestRefreshAction)2、往数据节点发送刷新请求的action(TransportRefreshAction)3、数据节点接收主节点refresh传输的action(TransportShardRefreshAction) 二、在IndexShard执行refresh操作1、根据入参决定是使用lucene提供的阻塞…

【华为数据之道学习笔记】3-8以确保合规遵从为核心的外部数据管理

一、以确保合规遵从为核心的外部数据管理 外部数据是指华为公司引入的外部组织或者个人拥有处置权利的 数据&#xff0c;如供应商资质证明、消费者洞察报告等。外部数据治理的出发点是合规遵从优先&#xff0c;与内部数据治理的目的不同。 外部数据的治理主要遵循以下原则。 1&…

【设计模式--创建型--原型模式】

设计模式--创建型--原型模式 原型模式概述结构实现结果 案例代码结果使用场景 扩展&#xff08;深\浅克隆&#xff09;浅克隆演示&#xff1a;结果&#xff1a;使用深克隆&#xff08;利用对象流&#xff09;结果 原型模式 概述 用一个已经创建的实例作为原型&#xff0c;通过…

Go简单了解

0.一直很好奇,go是不是像传说中的速度快,解决了多线程问题,快速进行了解了解,和java进行对比,他是怎么解决语言发展的问题的…,所有语言都是差不多的,只是熟练程度不同而已 1.go图标是土拨鼠,2009发行 docker使用go,解决了并发问题 google facebook 腾讯 百度 七牛云 京东 小米…

Spring Cloud Gateway + Nacos + LoadBalancer实现企业级网关

1. Spring Cloud Gateway 整合Nacos、LoadBalancer 实现企业级网关 前置工作&#xff1a; 创建 SpringBoot 多模块项目创建网关&#xff08;gateway-service&#xff09;、用户&#xff08;user-service&#xff09;模块用户模块添加 Nacos discovery 支持以及 Spring Web&am…

gitbash下载安装

参考教程 零、下载 官网地址 2.43.0win64 链接&#xff1a;https://pan.baidu.com/s/16urs_nmky7j20-qNzUTTkg 提取码&#xff1a;7jaq 一、安装 图标组件&#xff08;Additional icons&#xff09;&#xff1a;选择是否创建桌面快捷方式&#xff1b;桌面浏览&#xff08;Win…

设计模式--命令模式的简单例子

引入&#xff1a;以一个对数组的增删改查为例。通过命令模式可以对数组进行增删改查以及撤销回滚。 一、基本概念 命令模式有多种分法&#xff0c;在本文中主要分为CommandMgr、Command、Receiver. CommandMgr主要用于控制命令执行等操作、Command为具体的命令、Receiver为命…

逸迅科技丁红阳:三种能力帮助企业打造GBI “护城河”

大数据产业创新服务媒体 ——聚焦数据 改变商业 近日&#xff0c;由上海市经济和信息化委员会、上海市科学技术委员会指导&#xff0c;数据猿与上海大数据联盟联合主办的“2023企业数智化转型升级发展论坛”在上海举行。本次论坛以“释放数字价值驱动智能升级”为主题&#xf…

piakachu越权漏洞

水平越权 首先打开这一关&#xff0c;在右侧有一些提示&#xff0c;我们可以看到 然后我们随便输入一组信息即可&#xff0c;可以在url中看到这样的字段 当我们尝试在url中直接更换另一个用户名时可以发现&#xff0c;直接切换到了另一个用户的身份 垂直越权 这里可以看到右边…

QML和C++交互中,实现C++中connect到qml的信号,再从qml发射信号传递数据给C++的一种方式

1.需求&#xff1a; 假设我们有一个需求&#xff0c;要求在用户点击列表中的项目时&#xff0c;不仅在控制台上输出项目的名称&#xff0c;还要在C端进行一些处理。我们希望在C端能够接收到用户点击的项目名称&#xff0c;并进行相应的处理。 2.分析&#xff1a; 在这种情况…

Android 10.0 系统framework修改低电量关机值为2%

1.前言 在10.0的系统产品开发中,在系统关于低电量关机的值,每个平台都不同,根据实际开发底层硬件的要求看实际情况来调整这个值, 所以需要分析相关的电量变化执行的代码流程,来实现这个功能 2.系统framework修改低电量关机值为2%的核心类 frameworks\base\services\cor…

一文学会使用 PyInstaller 将 Python 脚本打包为 .exe 可执行文件

文章目录 前言PyInstaller特点跨平台支持自动依赖项处理单文件发布支持图形用户界面&#xff08;GUI&#xff09;和命令行界面&#xff08;CLI&#xff09;应用支持多种打包选项 基本用法常用参数其它参数 版本 & 环境实现步骤安装 PyInstaller创建 Python 脚本使用 PyInst…

Strange-Towers-of-Hanoi

title: Strange Towers of Hanoi date: 2023-12-11 03:20:05 tags: 递推 categories: 算法进阶指南 题目大意 解出 n n n 个盒子 4 4 4 座塔的汉诺塔问题最少需要多少次&#xff1f; 思路 首先考虑 n n n 个盒子 3 3 3 座塔的经典汉诺塔问题&#xff0c;设 d [ n ] d[n] …

第三十章 控制到 XML 模式的映射 - Array of Classname

文章目录 第三十章 控制到 XML 模式的映射 - Array of ClassnameArray of Classname 第三十章 控制到 XML 模式的映射 - Array of Classname Array of Classname 本部分显示了从启用 XML 的类生成的XML 架构的一部分&#xff0c;此时该类包含定义为类名数组的属性。例如&…

【SpringBoot教程】SpringBoot 创建定时任务(配合数据库动态执行)

作者简介&#xff1a;大家好&#xff0c;我是撸代码的羊驼&#xff0c;前阿里巴巴架构师&#xff0c;现某互联网公司CTO 联系v&#xff1a;sulny_ann&#xff08;17362204968&#xff09;&#xff0c;加我进群&#xff0c;大家一起学习&#xff0c;一起进步&#xff0c;一起对抗…