java-Stream流的常见方法
一 常见创建流的三种方式
//list集合创建流方式
new ArrayList<>().stream();
new HashSet<>().stream(); //map集合创建流方式, 原理同list
HashMap<Object, Object> map = new HashMap<>();
Stream<Object> stream2 = map.keySet().stream();
Stream<Object> stream3 = map.values().stream();
Stream<Map.Entry<Object, Object>> stream4 = map.entrySet().stream(); //数组创建流的方式(可变参数)
String[] arr = {"hello"};
Stream.of(arr);
解:map本身不可以直接创建流使用,但是可以单独拉出来当作list处理
二 stream 中间操作 filter 的使用(过滤操作,过滤后可能会减少数据)
List<String> list = new ArrayList<>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//以"张"开头的控制台输出
list.stream().filter(s->s.startsWith("张")).forEach(System.out::println);
//长度为3的在控制台输出
list.stream().filter(s->s.length() == 3).forEach(System.out::println);
//以"张"开头的并长度为3的在控制台输出
list.stream().filter(s->s.startsWith("张")).filter(s->s.length() == 3).forEach(System.out::println);
"System.out::println" 这种格式的叫方法引用同 "s->System.out.println(s)"
解:filter 是过滤数据,看是否否和条件返回布尔值,过滤过后数据会减少 , map 是最终返回一个结果,所以数据量上面不会变化,但有可能数据会发生改变
三 Stream 常见的中间操作limit & skip
List<String> list = new ArrayList<>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌"); //取前三个数据在控制台输出
list.stream().limit(3).forEach(System.out::println);
//跳过三个元素把剩余的元素的控制台输出
list.stream().skip(3).forEach(System.out::println);
//跳过两个元素,把剩下的元素中前两个元素在控制台输出
list.stream().skip(2).limit(2).forEach(System.out::println);
解:limit 是截取数据操作,skip 是跳跃数据操作。 对应括号填写相应的数
四 Stream 常见中间操作 concat & distanct
List<String> list = new ArrayList<>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌"); //取前4个组成一个流
Stream<String> limit = list.stream().limit(4);
//跳过两个数据组成一个流
Stream<String> skip = list.stream().skip(2);
//合并需求1和2流,并把结果在控制台输出
Stream.concat(limit,skip).forEach(System.out::println);
//合并需求1和2流,并把结果在控制台输出要求不能重复
Stream.concat(limit,skip).distinct().forEach(System.out::println);
解:concat 是合并操作,这里将两个流合并起来并输出(两个流互不影响), distinct 是数据去重操作。
五 Stream 常见中间操作 sorted
List<String> list = new ArrayList<>();
list.add("lingqingxia");
list.add("zhangmanyux");
list.add("wangzuxianx");
list.add("liuyan");
list.add("zhangmin");
list.add("zhangwuji"); //按照字母顺序排序在控制台输出
list.stream().sorted().forEach(System.out::println);
//按照字符串长度,然后按照字母顺序在控制台输出
list.stream().sorted((s1,s2)->{
int num = s1.length() - s2.length();
return num == 0 ? s1.compareTo(s2) : num;
}).forEach(System.out::println);
解:sorted 排序操作,默认按字典顺序排序
六 Stream 常见中间操作 Map(过滤后数据不会减少 可能修改了某些内容)
List<String> list = new ArrayList<>();
list.add("01");
list.add("10");
list.add("20");
list.add("30");
list.add("40");
list.add("50"); //对字符进行数据转换
list.stream().map(Integer::parseInt).forEach(System.out::println);
//mapToInt 不仅有map属性还带有特殊方法,求和求平均数等操作
list.stream().mapToInt(s->Integer.parseInt(s)).forEach(System.out::println);
//mapToInt 转换int并求和
int sum = list.stream().mapToInt(Integer::parseInt).sum();
System.out.println(sum);
解:map处理数据并不会影响最后数据的总量
七 Stream 终结操作 foreach & count
List<String> list = new ArrayList<>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//把集合中的元素在控制台输出控制台上
list.stream().forEach(System.out::println);
//把集合中的元素数量输出到控制台上
long count = list.stream().count();
System.out.println(count);
解: foreach 遍历循环操作,count 数量聚合操作
八 Stream 收集操作collection list
List<String> list = new ArrayList<>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌");
//生成流
Stream<String> listStream = list.stream().filter(s -> s.length() == 3);
//生成新的集合
List<String> stringList = listStream.collect(Collectors.toList());
Collections.toList() 变成list集合
Collections.toSet() 变成set集合
九 Stream 收集操作collection map
String[] arr = {"林青霞,33","张曼玉,28","柳岩,22"};
Map<String, String> maps = Stream.of(arr).collect(Collectors.toMap(s -> s.split(",")[0], s1 -> s1.split(",")[1]));
for (Map.Entry<String, String> entry : maps.entrySet()) {
System.out.println("姓名:"+entry.getKey()+",年龄"+entry.getValue());
}
Collections.toMap(k,v)
java-Stream流的常见方法的更多相关文章
- Java Stream流的使用
流相关的方法可以分为三种类型,分别是:获取Stream流.中间方法.终结方法.中间方法会返回当前流,可以方便的进行链式调用. 流不可重复使用,否则会报错: java.lang.IllegalState ...
- 一文带你入门Java Stream流,太强了
两个星期以前,就有读者强烈要求我写一篇 Java Stream 流的文章,我说市面上不是已经有很多了吗,结果你猜他怎么说:"就想看你写的啊!"你看你看,多么苍白的喜欢啊.那就&qu ...
- 全面吃透JAVA Stream流操作,让代码更加的优雅
全面吃透JAVA Stream流操作,让代码更加的优雅 在JAVA中,涉及到对数组.Collection等集合类中的元素进行操作的时候,通常会通过循环的方式进行逐个处理,或者使用Stream的方式进行 ...
- java字符流操作flush()方法及其注意事项
java字符流操作flush()方法及其注意事项 flush()方法介绍 查阅文档可以发现,IO流中每一个类都实现了Closeable接口,它们进行资源操作之后都需要执行close()方法将流关闭 ...
- Java Stream 流如何进行合并操作
1. 前言 Java Stream Api 提供了很多有用的 Api 让我们很方便将集合或者多个同类型的元素转换为流进行操作.今天我们来看看如何合并 Stream 流. 2. Stream 流的合并 ...
- Java Stream 流(JDK 8 新特性)
什么是 Steam Java 8 中新增了 Stream(流)来简化集合类的使用,Stream 本质上是个接口,接口中定义了很多对 Stream 对象的操作. 我们知道,Java 中 List 和 S ...
- Java | Stream流、泛型、多线程 | 整理自用
1.lambda 表达式 lambda 的延迟执行 可以对程序进行优化,尤其是使用 if {} else {} 条件判断,先判断条件是否成立,再传入计算好的参数. functionName( para ...
- 深度掌握 Java Stream 流操作,让你的代码高出一个逼格!
概念 Stream将要处理的元素集合看作一种流,在流的过程中,借助Stream API对流中的元素进行操作,比如:筛选.排序.聚合等. Stream 的操作符大体上分为两种:中间操作符和终止操作符 中 ...
- 这么简单,还不会使用java8 stream流的map()方法吗?
一.前言 在日常的开发工作中经常碰到要处理list中数据的问题,比如从数据库中查出了很多学生,由于一些原因需要在内存中找出这些学生中的所有姓名,或者把名为"王五"的语文成绩暂时修改 ...
- Java Stream流排序null以及获取指定条数数据
Java8的Stream流的一些用法, //排序 carerVehEntityList = carerVehEntityList.stream().sorted( Comparator.compari ...
随机推荐
- 这是一篇乖巧的草稿——vscode上传代码到代码托管平台GitHub
一.在GitHub上创建一个远程仓库: 以上,就创建好了一个名为pythonStudy的仓库,现在先别把它关掉,先最小化 二.安装版本管理工具git:git属于无脑安装,可以更改安装路径 打开项目文件 ...
- Vue3 企业级优雅实战 - 组件库框架 - 12 发布开源组件库
前面使用了 11 篇文章分享基于 vue3 .Monorepo 的组件库工程完整四件套(组件库.文档.example.cli)的开发.构建及组件库的发布.本文属于这 11 篇文章的扩展 -- 如何发布 ...
- Winform 程序多开
在使用应用程序的过程中,经常要求应用程序只能运行一次.如果发现重复开启,应从系统进程列表中搜索到已经开启的进程,并将该进程窗口移到最前端显示. 记录一下过程. 实现过程 在 Program.cs 文件 ...
- DevOps 与 FinOps:二者可以协同吗?
DevOps 是一个强调开发人员和运营团队之间的协作和自动化以创建更高效的软件开发生命周期的过程.随着云业务成本逐年攀升,甚至超过传统基础设施成本,许多企业开始转向 FinOps 以有效降本增效.Fi ...
- slate源码解析(二)- 基本框架与数据模型
源码架构 首先来看下最核心的slate包下的目录: 可以看到,作为一个开源富文本库,其源码是相当之少.在第一篇文章中说过,Slate没有任何开箱即用的功能,只提供给开发者用于构建富文本所需的最基本的一 ...
- 一文详解ATK Loss论文复现与代码实战
摘要:该方法的主要思想是使用数值较大的排在前面的梯度进行反向传播,可以认为是一种在线难例挖掘方法,该方法使模型讲注意力放在较难学习的样本上,以此让模型产生更好的效果. 本文分享自华为云社区<AT ...
- OpenLayers点聚合
1. 引言 当页面加载的数据量过大时,拖拽.缩放时往往会产生卡顿 然而,页面实现的内容是有限的,人眼可见范围也是有限的,过于微小的部分是可以不予显示的 聚合是解决这种问题的一个办法,当数据比较多,单个 ...
- PostgreSQL 并行计算算法,参数,强制并行度设置
一.优化器并行计算的并行度计算方法 1.总worker进程数 postgres=# show ; max_worker_processes ---------------------- 128 (1 ...
- because another server process exited abnormally and possibly corrupted shared memory
一.环境 系统平台:Linux x86-64 Red Hat Enterprise Linux 7 版本:4.1.1 二.症状 Red Hat 7.2操作系统部署HGDB 4.1.1后,日志经常出 ...
- LeetCode-1765 地图中的最高点
来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/map-of-highest-peak 题目描述 给你一个大小为 m x n 的整数矩阵 isWa ...