一  常见创建流的三种方式

        //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流的常见方法的更多相关文章

  1. Java Stream流的使用

    流相关的方法可以分为三种类型,分别是:获取Stream流.中间方法.终结方法.中间方法会返回当前流,可以方便的进行链式调用. 流不可重复使用,否则会报错: java.lang.IllegalState ...

  2. 一文带你入门Java Stream流,太强了

    两个星期以前,就有读者强烈要求我写一篇 Java Stream 流的文章,我说市面上不是已经有很多了吗,结果你猜他怎么说:"就想看你写的啊!"你看你看,多么苍白的喜欢啊.那就&qu ...

  3. 全面吃透JAVA Stream流操作,让代码更加的优雅

    全面吃透JAVA Stream流操作,让代码更加的优雅 在JAVA中,涉及到对数组.Collection等集合类中的元素进行操作的时候,通常会通过循环的方式进行逐个处理,或者使用Stream的方式进行 ...

  4. java字符流操作flush()方法及其注意事项

    java字符流操作flush()方法及其注意事项   flush()方法介绍 查阅文档可以发现,IO流中每一个类都实现了Closeable接口,它们进行资源操作之后都需要执行close()方法将流关闭 ...

  5. Java Stream 流如何进行合并操作

    1. 前言 Java Stream Api 提供了很多有用的 Api 让我们很方便将集合或者多个同类型的元素转换为流进行操作.今天我们来看看如何合并 Stream 流. 2. Stream 流的合并 ...

  6. Java Stream 流(JDK 8 新特性)

    什么是 Steam Java 8 中新增了 Stream(流)来简化集合类的使用,Stream 本质上是个接口,接口中定义了很多对 Stream 对象的操作. 我们知道,Java 中 List 和 S ...

  7. Java | Stream流、泛型、多线程 | 整理自用

    1.lambda 表达式 lambda 的延迟执行 可以对程序进行优化,尤其是使用 if {} else {} 条件判断,先判断条件是否成立,再传入计算好的参数. functionName( para ...

  8. 深度掌握 Java Stream 流操作,让你的代码高出一个逼格!

    概念 Stream将要处理的元素集合看作一种流,在流的过程中,借助Stream API对流中的元素进行操作,比如:筛选.排序.聚合等. Stream 的操作符大体上分为两种:中间操作符和终止操作符 中 ...

  9. 这么简单,还不会使用java8 stream流的map()方法吗?

    一.前言 在日常的开发工作中经常碰到要处理list中数据的问题,比如从数据库中查出了很多学生,由于一些原因需要在内存中找出这些学生中的所有姓名,或者把名为"王五"的语文成绩暂时修改 ...

  10. Java Stream流排序null以及获取指定条数数据

    Java8的Stream流的一些用法, //排序 carerVehEntityList = carerVehEntityList.stream().sorted( Comparator.compari ...

随机推荐

  1. python爬虫学习——元组,字典(2.14日博客补)

    元组 ''' tup1 = () #创建一个空的元组 print(type(tup1)) #tup2 = (50) #不是元组,python把括号当成了表达式的一部分,即数学运算的括号 #tup2 = ...

  2. angr初探

    前言 在搞fuzz的时候发现了一个比较难以解决的问题.例如if(*buf == "\xde\xad\xbe\xef"),我们如果想通过纯fuzz去进入这个if的分支,那么概率极其微 ...

  3. 使用JsonTextReader提高Json.NET反序列化的性能

    一.碰到的问题 在服务器的文件系统上有一个业务生成的BigTable.json文件,其可能包含的JSON字符串很大,同时里边的集合会包含很多的记录:我们使用以下的代码来反序列化,虽然使用了异步的Rea ...

  4. URL带参数json传递进行解析

    注意参数格式是要加密的: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...

  5. OpenLayers集成ECharts

    1. 引言 OpenLayers是WebGIS中常用的开源JavaScript前端库,ECharts是常用的可视化开源JavaScript前端库 OpenLayers官网:OpenLayers - W ...

  6. K8S 实用工具之一 - 如何合并多个 kubeconfig?

    开篇 引言: 磨刀不误砍柴工 工欲善其事必先利其器 K8S 集群规模,有的公司倾向于少量大规模 K8S 集群,也有的公司会倾向于大量小规模的 K8S 集群. 如果是第二种情况,是否有一个简单的 kub ...

  7. 4. Lighting 窗口

    Lighting 实现烘焙或者实时渲染都在这里设置,其他灯光或者反射探头的作用相当于允许 Lighting (窗口)烘焙或者实时渲染. 0bject: Lightmap Static: 把烘焙的对象设 ...

  8. centos7无法下载nginx

    centos7无法下载nginx   1.正常情况下:先下载epel-release 源然后安装yum install -y nginx2.如果不行,试着执行yum clean all &&a ...

  9. 这里记录一下我个人对AXI4主从模块的理解(这些理解主要来自阅读 Xilinx AXI_FULL_M_module 源码)

    先只考虑读请求: 以取指模块和内存模块为例,取指模块是发出请求的模块,因此为 Master,属于AXI4MasterModule:内存模块是响应请求的模块,因此为 Slave,属于AXI4SlaveM ...

  10. MySQL突然连接失败

    mysql突然连接失败问题 1.报错 MySQL error: 2013, "Lost connection to MySQL server at 'reading initial comm ...