当前位置: 首页 > news >正文

Stream流的思想和获取Stream流

首先介绍的概念:

流可以理解为一条流水线,在这条流水线中有许多操作,比如筛选所需要的数据,输出打印等,

经过这条流水线,可以获取到自己所需要的数据:

-->所以:

  • Stream流的作用:

结合了Lambda表达式,可以简化集合以及数组的操作;

  • Stream流的使用步骤:
    1. 先得到一条Stream流(流水线),并把数据放上去

    2. 利用Stream流中的中间API即中间方法(如数据过滤,类型转换)对流水线上的数据进行操作

    3. 利用Stream流中的终结API即终结方法(如数据统计,数据打印)对流水线上的数据进行操作

      中间方法:该方法调用完毕后,还可以调用其他方法;

      终结方法:最后一步,该方法调用完毕之后,不能再调用其他方法。


一.先得到一条Stream流(流水线),并把数据放上去:

1.获取Stream流的方法:

注:1)双列集合无法直接使用stream流,必须先用keySet方法(获取所有的键)或entrySet方法(获取到所有键值对对象的单

列集合)将其转换为单列集合,才能使用stream流

2)一堆零散数据必须是同种数据类型。

3)类Arrays里的stream方法:在类Arrays里,stream方法为静态的,可以直接类名.方法名进行调用:

4)一堆零散的数据获取stream流要用到接口Stream中的静态方法of(可以直接类名.方法名进行调用),该方法的形参

属于可变参数(可变参数底层就是一个数组),of方法返回Stream流。

2.获取Stream流的方法演示:

a.单列集合获取stream流:
获取stream流方法一:
package com.itheima.a01mystream;
​
import java.util.ArrayList;
import java.util.Collections;
import java.util.function.Consumer;
import java.util.stream.Stream;
​
public class StreamDemo2 {public static void main(String[] args) {//1.创建集合ArrayList<String> list=new ArrayList<>();
​//2.利用集合的工具类(Collections)添加数据Collections.addAll(list,"a","b","c","d","e");
​//3.获取stream流:要用到Collection这个接口中的默认方法stream/* ArrayList集合是Collection这个接口的实现类,所以可以直接调用默认方法stream *///获取到一条流水线,并把集合中的数据放到流水线上Stream<String> stream1 = list.stream();
​//4.使用终结方法打印一下流水线上的所有数据(用到了匿名内部类)stream1.forEach(new Consumer<String>() {@Overridepublic void accept(String s) {//s:依次表示流水线上的每一个数据System.out.println(s);}});}
}
获取stream流方法二:
package com.itheima.a01mystream;
​
import java.util.ArrayList;
import java.util.Collections;
​
public class StreamDemo2 {public static void main(String[] args) {//1.创建集合ArrayList<String> list=new ArrayList<>();
​//2.利用集合的工具类(Collections)添加数据Collections.addAll(list,"a","b","c","d","e");
​//3.利用链式编程,forEach方法和Lambda表达式进行遍历list.stream().forEach(s -> System.out.println(s));//s:依次表示流水线上的每一个数据}
}

代码解读:

  • stream方法:

  • forEach方法(可用于遍历):该方法的形参是函数式接口,因此可以写成匿名内部类,再改写为Lambda表达式

b.双列集合无法直接使用stream流,需要先用keySet方法(获取所有的键)或entrySet方法(获取到所有键值对对象的单列集合)将其转换为单列集合,才能使用stream流:
获取stream流方法一:
package com.itheima.a01mystream;
​
import java.util.HashMap;
​
public class StreamDemo3 {public static void main(String[] args) {//1.创建双列集合HashMap<String,Integer> hm=new HashMap<>();
​//2.添加数据hm.put("aaa",111);hm.put("bbb",222);hm.put("ccc",333);hm.put("ddd",444);
​//3.获取stream流/* hm.keySet()获取到了所有的键,是一个单列集合(Set集合);hm.keySet().stream()代表把所有的键放到了stream流这个流水线上*/hm.keySet().stream().forEach(s -> System.out.println(s));}
}

获取stream流方法二:
package com.itheima.a01mystream;
​
import java.util.HashMap;
​
public class StreamDemo3 {public static void main(String[] args) {//1.创建双列集合HashMap<String,Integer> hm=new HashMap<>();
​//2.添加数据hm.put("aaa",111);hm.put("bbb",222);hm.put("ccc",333);hm.put("ddd",444);
​//3.第二种获取stream流hm.entrySet().forEach(s-> System.out.println(s));//s依次表示键值对对象}
}

运行结果:

问题:添加数据的顺序和输出数据的顺序不一样,这是为什么?

因为HashMap集合底层是哈希表,它不能保证存和取的顺序一致,因此只要数据没错即可,顺序无所谓。

c.数组获取stream流:
存基本数据类型的数组获取stream流:
package com.itheima.a01mystream;
​
import java.util.Arrays;
​
public class StreamDemo4 {public static void main(String[] args) {//1.创建数组int[] arr={1,2,3,4,5,6,7,8,9,10};
​//2.获取stream流Arrays.stream(arr).forEach(s-> System.out.println(s));}
}
存引用数据类型的数组获取stream流:
package com.itheima.a01mystream;
​
import java.util.Arrays;
​
public class StreamDemo4 {public static void main(String[] args) {//1.创建数组String[] arr={"a","b","c"};
​//2.获取stream流Arrays.stream(arr).forEach(s-> System.out.println(s));}
}

代码解读:

1. 类Arrays里的stream方法:在类Arrays里,stream方法为静态的,可以直接类名.方法名进行调用

2.类Arrays里重载了许多stream方法:

当数组存引用数据类型时,会用上述图片中第一个stream方法来获取stream流。

d.一堆零散的数据获取stream流:这堆零散的数据必须是同种类型
方法of的形参是基本数据类型时:
package com.itheima.a01mystream;
​
import java.util.stream.Stream;
​
public class StreamDemo5 {public static void main(String[] args) {Stream.of(1,2,3,4,5).forEach(s-> System.out.println(s));}
}
​
方法of的形参是引用数据类型时:
package com.itheima.a01mystream;
​
import java.util.stream.Stream;
​
public class StreamDemo5 {public static void main(String[] args) {Stream.of("a","aa","aaa").forEach(s-> System.out.println(s));}
}

二.注意事项:

用接口Stream中的静态方法of获取stream流除了一堆零散的数据外可用,比如数组也是可以的,因为of方法的形参

属于可变参数(可变参数底层就是一个数组),例如:

package a41practice;
​
import java.util.stream.Stream;
​
public class Test {public static void main(String[] args) {//1.创建数组String[] arr2={"a","b","c"};
​//2.获取stream流Stream.of(arr2).forEach(s-> System.out.print(s+" "));/* 运行结果为a b c */}
}

但上述的方式是错误的,因为数组存的不仅仅有引用数据类型,还有基本数据类型,如下:

package a41practice;
​
import java.util.stream.Stream;
​
public class Test {public static void main(String[] args) {//1.创建数组int[] arr1={1,2,3,4,5,6,7,8,9,10};
​//2.获取stream流Stream.of(arr1).forEach(s-> System.out.print(s+" "));/* 运行结果为[I@7291c18f */}
}

此时无法做到遍历数据,打印出了地址值。

Stream接口中静态方法of的细节:

该方法的形参是一个可变参数,可以传递一堆的零散数据,也可以传递数组,

但数组存的数据必须是引用数据类型的,如果数组存基本数据类型,静态方法of是会把整个数组当成一个元素,放到

Stream流中,最后输出地址值,而不是数据。

相关文章:

Stream流的思想和获取Stream流

首先介绍流的概念&#xff1a; 流可以理解为一条流水线&#xff0c;在这条流水线中有许多操作&#xff0c;比如筛选所需要的数据&#xff0c;输出打印等&#xff0c; 经过这条流水线&#xff0c;可以获取到自己所需要的数据&#xff1a; -->所以&#xff1a; Stream流的作…...

go语言中的切片详解

1.概念 在Go语言中&#xff0c;切片&#xff08;Slice&#xff09;是一种基于数组的更高级的数据结构&#xff0c;它提供了一种灵活、动态的方式来处理序列数据。切片在Go中非常常用&#xff0c;因为它们可以动态地增长和缩小&#xff0c;这使得它们比固定大小的数组更加灵活。…...

ElK 8 收集 Nginx 日志

1. 说明 elk 版本&#xff1a;8.15.0 2. 启个 nginx 有 nginx 可以直接使用。我这里是在之前环境下 docker-compose.yml 中启动了个 nginx&#xff1a; nginx:restart: alwaysimage: nginx:1.26.1ports:- "80:80"- "443:443"volumes:#- ./nginx/html:/…...

Xv6驱动(四):CLINT

阅读材料 Xv6代码&#xff1a;memlayout.h、start.c、kernelvec.S教材5.4节 CLINT内存映射 实际上&#xff0c;CLINT还包括若干个MSIP寄存器&#xff0c;用来触发软件中断&#xff0c;但是在Xv6中不考虑软件中断&#xff0c;因此这些寄存器也不用考虑 // core local interr…...

【LInux】HTTPS是如何实现安全传输的

1. 客户端发起HTTPS连接请求 当浏览器请求一个HTTPS网址时&#xff0c;客户端&#xff08;例如浏览器&#xff09;会向服务器发起一个HTTPS请求。 2. 服务器返回数字证书 服务器收到请求后&#xff0c;会向客户端发送包含公钥的数字证书。数字证书由**权威认证机构&#xff…...

英飞凌PSoC4000T的GPIO中断示例工程

关于PSoC4000T的初步介绍见:英飞凌MCU第五代高性能CAPSENSE技术PSoC4000T_psoc 4000t-CSDN博客 下面这个工程,在modustoolbox中可编译、下载到开发板、debug调试。 编译时会用到mtb_shared这个库: 已经pdl这个periperal driver library库:...

物联网(IoT)中基于深度学习的入侵检测系统的综合综述

这篇论文是一篇全面的综述&#xff0c;标题为“A comprehensive survey on deep learning-based intrusion detection systems in Internet of Things (IoT)”&#xff0c;作者是Qasem Abu Al-Haija和Ayat Droos。论文主要探讨了在物联网(IoT)环境中基于深度学习的入侵检测系统…...

《成都体育学院学报》

投稿指南 成都体育学院学报属于体育类型期刊&#xff0c;由成都体育学院主办&#xff0c;国内统一刊号&#xff1a;51-1097/G8&#xff0c;国际标准刊号&#xff1a;1001-9154&#xff0c;双月&#xff0c;面向国内外公开发行。 一、来稿必须是作者独立取得的原创性学术研究成…...

Flask-JWT-Extended登录验证, 不用自定义

"""安装:pip install Flask-JWT-Extended创建对象 初始化与app绑定jwt JWTManager(app) # 初始化JWTManager设置 Cookie 的选项:除了设置 cookie 的名称和值之外&#xff0c;你还可以指定其他的选项&#xff0c;例如&#xff1a;过期时间 (max_age)&#xff1…...

rpm 与 yum

11 rpm -qa | grep openssh rpm与 yum CentOS仅删除软件包本身而不删除依赖 https://blog.csdn.net/kangshuaibi/article/details/125472204...

几种修改docker默认存储位置的方法

需求 docker容器存放目录磁盘空间满了&#xff0c;需要转移数据&#xff0c;修改Docker默认存储位置 解决方法 方法&#xff11;&#xff1a;迁移到新目录 停止docker服务。 1systemctl stop docker; //每个liunx版本的命令不一样。创建新的docker目录&#xff0c;执行命令df…...

istio中如何使用serviceentry引入外部服务

假设需要引入一个外部服务&#xff0c;外部服务ip为10.10.102.90&#xff0c;端口为32033. 引入到istio中后&#xff0c;我想通过域名gindemo.test.ch:9090来访问这个服务。 serviceentry yaml内容如下&#xff1a; apiVersion: networking.istio.io/v1beta1 kind: ServiceEn…...

模仿抖音用户ID加密ID的算法MB4E,提高自己平台ID安全性

先看抖音的格式 对ID加密的格式 MB4EENgLILJPeQKhJht-rjcc6y0ECMk_RGTceg6JBAA 需求是 同一个ID 比如 413884936367560 每次获取得到的加密ID都是不同的&#xff0c;最终解密的ID都是413884936367560 注意这是一个加密后可解密原文的方式&#xff0c;不是单向加密 那么如下进行…...

solidwork镜像实体

效果如下&#xff1a; 可以看到这两条线是对称的。 第一步&#xff0c;点击这条要镜像的边&#xff0c;接着点击镜像实体。 然后选择镜像轴&#xff0c;即可...

第6天:趋势轮动策略开发(年化18.8%,大小盘轮动加择时)

原创内容第655篇&#xff0c;专注量化投资、个人成长与财富自由。 轮动策略是一种投资策略&#xff0c;它涉及在不同的资产类别、行业或市场之间进行切换&#xff0c;以捕捉市场机会并优化投资组合的表现。 这种策略的核心在于识别并利用不同资产或市场的相对强弱&#xff0c…...

米客方德SD NAND 掉电测试

SD NAND 异常上下电测试的作用 SD NAND 异常上下电测试是一项关键的测试步骤&#xff0c;对确保SD NAND在不同电源条件下的稳定性和可靠性至关重要。 通过模拟正常和异常电源情况&#xff0c;测试可以验证设备的电源管理功能、检测潜在错误和异常行为&#xff0c;并评估设备在…...

深入探索Android开发之Kotlin核心技术学习大全

Android作为全球最流行的移动操作系统之一&#xff0c;其开发技能的需求日益增长。本文将为您介绍一套专为Android开发者设计的Kotlin核心技术学习资料&#xff0c;包括详细的学习大纲、PDF文档、源代码以及配套视频教程&#xff0c;帮助您从Kotlin基础到高级特性&#xff0c;再…...

langchain报错记录(js)

文章目录 [ERR_PACKAGE_PATH_NOT_EXPORTED]报错&#xff1a;报错语句&#xff1a;思路&#xff1a;解决方法&#xff1a; [ERR_PACKAGE_PATH_NOT_EXPORTED] 报错&#xff1a; Error [ERR_PACKAGE_PATH_NOT_EXPORTED]: Package subpath ‘./dist/prompts/’ is not defined by…...

VSCode调试Unity准备工作

一.Unity设置VSCode为默认编辑器 Unity编辑器中Edit-Preferences-External Tools中选择VSCode 二.VSCode安装Unity插件 三.Unity的Visual Studio Editor升至最新 Window->Package Manager->Visual Studio Editor 四.下载配置.Net 8.0 安装之前VSCode会提示你下载.Net …...

缓存穿透 问题(缓存空对象)

文章目录 1、缓存穿透2、缓存空对象3、AlbumInfoApiController --》getAlbumInfo()4、AlbumInfoServiceImpl --》getAlbumInfo()5、RedisConstant6、请求缓存不存在的数据 1、缓存穿透 2、缓存空对象 3、AlbumInfoApiController --》getAlbumInfo() GetMapping("getAlbumI…...

Debian系统简介

目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版&#xff…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

如何在网页里填写 PDF 表格?

有时候&#xff0c;你可能希望用户能在你的网站上填写 PDF 表单。然而&#xff0c;这件事并不简单&#xff0c;因为 PDF 并不是一种原生的网页格式。虽然浏览器可以显示 PDF 文件&#xff0c;但原生并不支持编辑或填写它们。更糟的是&#xff0c;如果你想收集表单数据&#xff…...

Linux C语言网络编程详细入门教程:如何一步步实现TCP服务端与客户端通信

文章目录 Linux C语言网络编程详细入门教程&#xff1a;如何一步步实现TCP服务端与客户端通信前言一、网络通信基础概念二、服务端与客户端的完整流程图解三、每一步的详细讲解和代码示例1. 创建Socket&#xff08;服务端和客户端都要&#xff09;2. 绑定本地地址和端口&#x…...

基于TurtleBot3在Gazebo地图实现机器人远程控制

1. TurtleBot3环境配置 # 下载TurtleBot3核心包 mkdir -p ~/catkin_ws/src cd ~/catkin_ws/src git clone -b noetic-devel https://github.com/ROBOTIS-GIT/turtlebot3.git git clone -b noetic https://github.com/ROBOTIS-GIT/turtlebot3_msgs.git git clone -b noetic-dev…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf

FTP 客服管理系统 实现kefu123登录&#xff0c;不允许匿名访问&#xff0c;kefu只能访问/data/kefu目录&#xff0c;不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

Mysql8 忘记密码重置,以及问题解决

1.使用免密登录 找到配置MySQL文件&#xff0c;我的文件路径是/etc/mysql/my.cnf&#xff0c;有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...

mac 安装homebrew (nvm 及git)

mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用&#xff1a; 方法一&#xff1a;使用 Homebrew 安装 Git&#xff08;推荐&#xff09; 步骤如下&#xff1a;打开终端&#xff08;Terminal.app&#xff09; 1.安装 Homebrew…...

第7篇:中间件全链路监控与 SQL 性能分析实践

7.1 章节导读 在构建数据库中间件的过程中&#xff0c;可观测性 和 性能分析 是保障系统稳定性与可维护性的核心能力。 特别是在复杂分布式场景中&#xff0c;必须做到&#xff1a; &#x1f50d; 追踪每一条 SQL 的生命周期&#xff08;从入口到数据库执行&#xff09;&#…...

深入理解Optional:处理空指针异常

1. 使用Optional处理可能为空的集合 在Java开发中&#xff0c;集合判空是一个常见但容易出错的场景。传统方式虽然可行&#xff0c;但存在一些潜在问题&#xff1a; // 传统判空方式 if (!CollectionUtils.isEmpty(userInfoList)) {for (UserInfo userInfo : userInfoList) {…...