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

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>() {
            @Override
            public 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流中,最后输出地址值,而不是数据。


http://www.kler.cn/news/304333.html

相关文章:

  • 设计模式重新整理
  • 中秋出游热度十足!喆啡酒店如何巧妙捕捉多元旅游需求?
  • 遥感技术在生态系统碳储量、碳收支、碳排放、碳循环以及人为源排放反演等领域的技术发展,实践角度解决遥感技术在生态、能源、大气等领域的碳排放监测及模拟问题
  • C++ | Leetcode C++题解之第397题整数替换
  • Coggle数据科学 | 科大讯飞AI大赛:人岗匹配挑战赛 赛季3
  • 怎么将几个pdf合成为一个?把几个PDF合并成为一个的8种方法
  • opencv图像透视处理
  • 机器学习(西瓜书)第 6 章 支持向量机
  • Jupyter notebook配置与使用(安装过程+环境配置+运行实例)
  • redis基本数据结构-string
  • 关于OceanBase 多模一体化的浅析
  • 探索螺钉设计:部分螺纹与全螺纹,哪种更适合你的项目?
  • 学习笔记 韩顺平 零基础30天学会Java(2024.9.14)
  • HashMap在并发场景下的问题
  • hku-mars雷达相机时间同步方案-硬件(MID360与海康MV-CB060-10UMUC-S)
  • Spring-cloud-gateway报错问题总结
  • 卷轴模式系统中的任务起源探索与趣味性设计策略分析
  • 【大模型专栏—进阶篇】语言模型创新大总结——“后起之秀”
  • rocketmq-client5.2手动给生产者和消费者设置access-key和secret-key值
  • Sparse4D v1
  • 从零开始学PostgreSQL (十四):高级功能
  • 【来学Vue吧】创建一个Vue项目
  • 通过adb命令打开手机usb调试
  • 青铜级与大师级删库跑路:黑色幽默的背后
  • 几何概率模型
  • GEE 教程:利用sentinel-5p数据进行长时序CO一氧化碳的监测分析并结合夜间灯光数据分析
  • 使用Vue3+TS玩转高德地图
  • 前端表单验证的常见问题与解决方案
  • helm一键化部署pod
  • 基于Linux和C++实现的RabbitMQ风格消息队列:设计与实现