Java——Stream流(2/2):Stream流的中间方法、终结方法(方法、案例演示)

简介: Java——Stream流(2/2):Stream流的中间方法、终结方法(方法、案例演示)

Stream流的中间方法

方法

  • 中间方法指的是调用完成后会返回新的Stream流,可以继续使用(支持链式编程)。

图片.png

案例演示

需求1:找出成绩大于等60分的数据,并升序后,再输出。

public class streamTest3 {
    public static void main(String[] args) {
        List<Double> scores = new ArrayList<>();
        Collections.addAll(scores,88.5,100.0,60.0,99.0,9.5,99.6,25.0);
        //需求1:找出成绩大于等于60分的数据,并升序后,再输出。
        scores.stream().filter(s -> s >= 60).sorted().forEach(s -> System.out.println(s));
    }
}

运行结果:


需求2:找出年龄大于等于23,且年龄小于等于30岁的学生,并按照年龄降序输出。

public class streamTest3 {
    public static void main(String[] args) {
 
        List<Student> students = new ArrayList<>();
        Student s1 = new Student("蜘蛛精", 172.5,26 );
        Student s2 = new Student("蜘蛛精",172.5,26);
        Student s3 = new Student("紫霞",167.6,23);
        Student s4 = new Student("白晶晶",169.0,25);
        Student s5 = new Student("牛魔王",183.3,35);
        Student s6 = new Student("牛夫人",168.5,34);
        Collections.addAll(students,s1,s2,s3,s4,s5,s6);
 
        //需求2:找出年龄大于等于23,且年龄小于等于30岁的学生,并按照年龄降序输出。
        students.stream().filter(s -> s.getAge() >= 23 && s.getAge() <= 30)
                .sorted((o1,o2) -> o2.getAge() - o1.getAge())  //重载的sort方法
                .forEach(s -> System.out.println(s));
    }
}

运行结果:


需求3:取出身高最高的前3名学生,并输出。

    //需求3:取出身高最高的前3名学生,并输出。
    students.stream().sorted((o1,o2) -> Double.compare(o2.getHeight(),o1.getHeight()))
                .limit(3).forEach(s -> System.out.println(s));

运行结果:


再简化输出语句:


需求4:取出身高倒数的2名学生

//需求4:取出身高倒数的2名学生
students.stream().sorted((o1,o2) -> Double.compare(o2.getHeight(),o1.getHeight()))
      .skip(students.size() - 2).forEach(System.out::println);

运行结果:


需求5:找出身高超过168的学生叫什么名字,要求去除重复的名字,再输出。

//需求5:找出身高超过168的学生叫什么名字,要求去除重复的名字,再输出。
students.stream().filter(s -> s.getHeight() > 168)
        .map(Student::getName /* s->s.getName()*/ )
        .distinct().forEach(System.out::println);

运行结果:


concat的使用

Stream<String> st1 = Stream.of("张三","李四");
Stream<String> st2 = Stream.of("张三2","李四2","王五");
Stream<String> allSt = Stream.concat(st1,st2);
allSt.forEach(System.out::println);

运行结果:


Stream流的终结方法

方法

  • 终结方法指的是调用完成后,不会返回新Stream了,没法继续使用流了。
  • 图片.png

案例演示1

需求1:计算出身高超过168的学生有几人

public class streamTest4 {
    public static void main(String[] args) {
        List<Student> students = new ArrayList<>();
        Student s1 = new Student("蜘蛛精", 172.5,26 );
        Student s2 = new Student("蜘蛛精",172.5,26);
        Student s3 = new Student("紫霞",167.6,23);
        Student s4 = new Student("白晶晶",169.0,25);
        Student s5 = new Student("牛魔王",183.3,35);
        Student s6 = new Student("牛夫人",168.5,34);
        Collections.addAll(students,s1,s2,s3,s4,s5,s6);
 
        //需求1:计算出身高超过168的学生有几人
        long size = students.stream().filter(s -> s.getHeight() > 168).count();
        System.out.println(size);
    }
}

运行结果:


需求2:请找出身高最高的学生对象,并输出

//需求2:请找出身高最高的学生对象,并输出
Student s = students.stream().max((o1,o2) -> 
        Double.compare(o1.getHeight(),o2.getHeight())).get();
System.out.println(s);

运行结果:


需求3:请找出身高最矮的学生对象,并输出

//需求3:请找出身高最矮的学生对象,并输出
Student ss = students.stream().min((o1,o2) -> 
    Double.compare(o1.getHeight(),o2.getHeight())).get();
System.out.println(ss);

运行结果:


收集

  • 收集Stream流:就是把Stream流操作后的结果转回到集合或者数组中去返回。

Stream流:方便操作集合/数组的手段;集合/数组:才是开发中的目的

Stream提供的常用终结方法 说明
R collect(Collector collector) 把流处理后的结果收集到一个指定的集合中去
Object[] toArray() 把流处理后的结果收集到一个数组中去

图片.png

案例演示2

需求4:请找出身高超过170的学生对象,并放到一个新集合中去返回

//需求4:请找出身高超过170的学生对象,并放到一个新集合中去返回
List<Student> students1 = students.stream().filter(a -> a.getHeight() > 170).collect(Collectors.toList());
System.out.println(students1);
System.out.println("-----------------------");
Set<Student> students2 = students.stream().filter(a -> a.getHeight() > 170).collect(Collectors.toSet());
System.out.println(students2);

运行结果:


注意:流只能收集一次       (就像是水喝光了,或者是迭代器的指针指到了最后的位置)

例如:


需求5:请找出身高超过170的学生对象,并把学生对象的名字和身高,存入到一个Map集合返回。

(需要手动去重)

//需求5:请找出身高超过170的学生对象,并把学生对象的名字和身高,存入到一个Map集合返回。
Map<String,Double> map =
    students.stream().filter(a -> a.getHeight() > 170)
    .distinct().collect(Collectors.toMap(a -> a.getName(),a -> a.getHeight()));
System.out.println(map);

运行结果:


Stream流收集为数组

Object[] arr1 = students.stream().filter(a -> a.getHeight() > 170).toArray();
 
//如果不想要Object类型,则
Student[] arr2 = students.stream().filter(a -> a.getHeight() > 170).toArray(len -> new Student[len]);
System.out.println(Arrays.toString(arr2));

运行结果:



END



目录
相关文章
|
1月前
|
存储 Java 数据挖掘
Java 8 新特性之 Stream API:函数式编程风格的数据处理范式
Java 8 引入的 Stream API 提供了一种新的数据处理方式,支持函数式编程风格,能够高效、简洁地处理集合数据,实现过滤、映射、聚合等操作。
63 6
|
1月前
|
Java API 开发者
Java中的Lambda表达式与Stream API的协同作用
在本文中,我们将探讨Java 8引入的Lambda表达式和Stream API如何改变我们处理集合和数组的方式。Lambda表达式提供了一种简洁的方法来表达代码块,而Stream API则允许我们对数据流进行高级操作,如过滤、映射和归约。通过结合使用这两种技术,我们可以以声明式的方式编写更简洁、更易于理解和维护的代码。本文将介绍Lambda表达式和Stream API的基本概念,并通过示例展示它们在实际项目中的应用。
|
2月前
|
安全 Java 开发者
Java中WAIT和NOTIFY方法必须在同步块中调用的原因
在Java多线程编程中,`wait()`和`notify()`方法是实现线程间协作的关键。这两个方法必须在同步块或同步方法中调用,这一要求背后有着深刻的原因。本文将深入探讨为什么`wait()`和`notify()`方法必须在同步块中调用,以及这一机制如何确保线程安全和避免死锁。
47 4
|
2月前
|
Java
深入探讨Java中的中断机制:INTERRUPTED和ISINTERRUPTED方法详解
在Java多线程编程中,中断机制是协调线程行为的重要手段。了解和正确使用中断机制对于编写高效、可靠的并发程序至关重要。本文将深入探讨Java中的`Thread.interrupted()`和`Thread.isInterrupted()`方法的区别及其应用场景。
68 4
|
2月前
|
Java 数据处理 数据安全/隐私保护
Java处理数据接口方法
Java处理数据接口方法
29 1
|
29天前
|
Rust 安全 Java
Java Stream 使用指南
本文介绍了Java中Stream流的使用方法,包括如何创建Stream流、中间操作(如map、filter、sorted等)和终结操作(如collect、forEach等)。此外,还讲解了并行流的概念及其可能带来的线程安全问题,并给出了示例代码。
|
2月前
|
安全 Java API
Java中的Lambda表达式与Stream API的高效结合####
探索Java编程中Lambda表达式与Stream API如何携手并进,提升数据处理效率,实现代码简洁性与功能性的双重飞跃。 ####
32 0
|
Java
Java8中stream流处理数据21个小案例(学习使用)
Java8中stream流处理数据21个小案例(学习使用)
103 0
|
SQL 存储 前端开发
【Java技术指南】「Java8技术盲区」在奔向Java13的同时,也让我们仔细研究一下Stream的学习认知!
【Java技术指南】「Java8技术盲区」在奔向Java13的同时,也让我们仔细研究一下Stream的学习认知!
150 0
【Java技术指南】「Java8技术盲区」在奔向Java13的同时,也让我们仔细研究一下Stream的学习认知!
|
Java 程序员 API
Java 8 Stream API学习总结
Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据。Stream API可以极大提高Java程序员的生产力,让程序员写出高效率、干净、简洁的代码。这种风格将要处理的元素集合看作一种流, 流在管道中传输, 并且可以在管道的节点上进行处理, 比如筛选, 排序,聚合等。
1044 0
下一篇
开通oss服务