Java Stream API 操作完全攻略:让你的代码更加出色 (三)

简介: Java Stream 是一种强大的数据处理工具,可以帮助开发人员快速高效地处理和转换数据流。使用 Stream 操作可以大大简化代码,使其更具可读性和可维护性,从而提高开发效率。本文将为您介绍 Java Stream 操作的所有方面,包括 groupingBy、groupingBy、joining、mapping 等操作,让你的代码行云流水,更加优雅。

前言
  Java Stream 是一种强大的数据处理工具,可以帮助开发人员快速高效地处理和转换数据流。使用 Stream 操作可以大大简化代码,使其更具可读性和可维护性,从而提高开发效率。本文将为您介绍 Java Stream 操作的所有方面,包括 groupingBy、groupingBy、joining、mapping 等操作,让你的代码行云流水,更加优雅。

groupingBy():按照指定条件对 Stream 中的元素进行分组。
partitioningBy():按照指定条件对 Stream 中的元素进行分区。
joining():将 Stream 中的元素连接成一个字符串。
mapping():根据指定的 Function 对 Stream 中的元素进行映射,并返回一个新的 Stream。
flatMapping():将每个元素映射为一个 Stream,然后将这些 Stream 连接成一个 Stream。
iterating():使用指定的种子值创建一个 Stream,并依次对每个元素进行指定的操作。
empty():返回一个空的 Stream。
of():根据指定的元素创建一个 Stream。
concat():将多个 Stream 连接成一个 Stream。
unordered():返回一个无序的 Stream。

示例

  1. 使用 groupingBy() 按照字符串长度对字符串列表进行分组

代码示例:
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class GroupingByExample {

public static void main(String[] args) {
    List<String> stringList = Arrays.asList("hello", "world", "java", "stream");

    Map<Integer, List<String>> result = stringList.stream()
            .collect(Collectors.groupingBy(String::length));

    System.out.println(result);
}

}
复制代码
输出结果:
{5=[hello, world], 4=[java], 6=[stream]}
复制代码
2.使用 partitioningBy() 将数字列表按照是否为偶数进行分区
代码示例:
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;

public class PartitioningByExample {

public static void main(String[] args) {
    List<Integer> numberList = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

    Map<Boolean, List<Integer>> result = numberList.stream()
            .collect(Collectors.partitioningBy(n -> n % 2 == 0));

    System.out.println(result);
}

}
复制代码
输出结果:
{false=[1, 3, 5, 7, 9], true=[2, 4, 6, 8, 10]}
复制代码
3.使用 joining() 将字符串列表中的元素用逗号连接成一个字符串
代码示例:
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class JoiningByExample {

public static void main(String[] args) {
    List<String> stringList = Arrays.asList("hello", "world", "java", "stream");

    String result = stringList.stream()
            .collect(Collectors.joining(","));

    System.out.println(result);
}

}
复制代码
输出结果:
hello,world,java,stream
复制代码
4.使用 mapping() 将字符串列表中的元素转换为大写字母
代码示例:
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class MappingByExample {

public static void main(String[] args) {
    List<String> stringList = Arrays.asList("hello", "world", "java", "stream");

    List<String> result = stringList.stream()
            .map(String::toUpperCase)
            .collect(Collectors.toList());

    System.out.println(result);
}

}
复制代码
输出结果:
[HELLO, WORLD, JAVA, STREAM]
复制代码
5.使用 flatMapping() 将嵌套的字符串列表展平为一个字符串列表
代码示例:
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class FlatMappingByExample {

public static void main(String[] args) {
    List<List<String>> nestedList = Arrays.asList(
            Arrays.asList("hello", "world"),
            Arrays.asList("hello","java", "stream"));

    List<String> result = nestedList.stream()
            .flatMap(List::stream)
            .distinct()
            .collect(Collectors.toList());

    System.out.println(result);
}

}
复制代码
输出结果:
[hello, world, java, stream]
复制代码
6.使用 iterating() 生成斐波那契数列前 10 项
代码示例:
import java.util.stream.Stream;

public class IteratingByExample {

public static void main(String[] args) {
    Stream.iterate(new int[]{0, 1}, t -> new int[]{t[1], t[0] + t[1]})
            .limit(10)
            .map(t -> t[0])
            .forEach(System.out::println);
}

}
复制代码
输出结果:
0
1
1
2
3
5
8
13
21
34
复制代码
7.使用 empty() 使用空的 Stream
代码示例:
import java.util.stream.Stream;

public class EmptyStreamExample {

public static void main(String[] args) {
    Stream<String> emptyStream = Stream.empty();

    System.out.println(emptyStream.count());
}

}
复制代码
输出结果:
0
复制代码
8.使用 of() 创建包含一些字符串的 Stream
代码示例:
import java.util.stream.Stream;

public class OfStreamExample {

public static void main(String[] args) {
    Stream<String> stringStream = Stream.of("hello", "world", "java", "stream");

    stringStream.forEach(System.out::println);
}

}
复制代码
输出结果:
hello
world
java
stream
复制代码
9.使用 concat() 将两个字符串列表合并为一个列表
代码示例:
import java.util.Arrays;
import java.util.List;
import java.util.stream.Stream;

public class ConcatStreamExample {

public static void main(String[] args) {
    List<String> list1 = Arrays.asList("hello", "world");
    List<String> list2 = Arrays.asList("java", "stream");

    Stream<String> stream1 = list1.stream();
    Stream<String> stream2 = list2.stream();

    List<String> result = Stream.concat(stream1, stream2)
            .collect(Collectors.toList());

    System.out.println(result);
}

}
复制代码
输出结果:
[hello, world, java, stream]
复制代码
10.使用 unordered() 对数字列表进行排序后,使用 unordered()返回一个无序的 Stream
代码示例:
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class UnorderedStreamExample {

public static void main(String[] args) {
    List<Integer> numberList = Arrays.asList(1, 3, 2, 4, 10, 6, 8, 7, 9, 6);

    List<Integer> result = numberList.stream()
            .sorted()
            .unordered()
            .collect(Collectors.toList());

    System.out.println(result);
}

}
复制代码
输出结果:
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
复制代码
来个小坑

  感谢大佬看到这里,如果你看完觉得没问题,那么你需要反思一下了哦。好了我们可以在仔细地看看,示例10.unordered()的代码。
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class UnorderedStreamExample {

public static void main(String[] args) {
    List<Integer> numberList = Arrays.asList(1, 3, 2, 4, 10, 6, 8, 7, 9, 6);

    List<Integer> result = numberList.stream()
            .sorted()
            .unordered()
            .collect(Collectors.toList());

    System.out.println(result);
}

}
复制代码
输出结果:
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
复制代码
  执行过程分析,首先输入了一个无序的流,然后使用sorted()对流进行排序,然后在使用unordered(),去除流的有序约束。然后输出为List,再进行打印出来。按理来说,输出的顺序应该是一个无序的,而不是有序的。

解答
  unordered()操作不会执行任何操作来显式地对流进行排序。它的作用是消除了流必须保持有序的约束,从而允许后续操作使用不必考虑排序的优化。
  对于顺序流,顺序的存在与否不会影响性能,只影响确定性。如果流是顺序的,则在相同的源上重复执行相同的流管道将产生相同的结果;如果是非顺序流,重复执行可能会产生不同的结果。
  unordered()操作,是消除了流必须保持有序的约束。并不会改变,流原有的顺序。对于并行流,放宽排序约束有时可以实现更高效的执行。在流有序时, 但用户不特别关心该顺序的情况下,使用 unordered() 明确地对流进行去除有序约束可以改善某些有状态或终端操作的并行性能。

相关文章
|
16天前
|
存储 安全 Java
Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
【10月更文挑战第17天】Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
38 2
|
16天前
|
存储 Java API
键值对魔法:如何优雅地使用Java Map,让代码更简洁?
键值对魔法:如何优雅地使用Java Map,让代码更简洁?
70 2
|
9天前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
19 5
Java反射机制:解锁代码的无限可能
|
1天前
|
缓存 监控 Java
如何运用JAVA开发API接口?
本文详细介绍了如何使用Java开发API接口,涵盖创建、实现、测试和部署接口的关键步骤。同时,讨论了接口的安全性设计和设计原则,帮助开发者构建高效、安全、易于维护的API接口。
14 4
|
5天前
|
jenkins Java 测试技术
如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例详细说明
本文介绍了如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例,详细说明了从 Jenkins 安装配置到自动构建、测试和部署的全流程。文中还提供了一个 Jenkinsfile 示例,并分享了实践经验,强调了版本控制、自动化测试等关键点的重要性。
28 3
|
11天前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
40 10
|
6天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
5天前
|
Java
Java代码解释++i和i++的五个主要区别
本文介绍了前缀递增(++i)和后缀递增(i++)的区别。两者在独立语句中无差异,但在赋值表达式中,i++ 返回原值,++i 返回新值;在复杂表达式中计算顺序不同;在循环中虽结果相同但使用方式有别。最后通过 `Counter` 类模拟了两者的内部实现原理。
Java代码解释++i和i++的五个主要区别
|
9天前
|
Java API 数据处理
探索Java中的Lambda表达式与Stream API
【10月更文挑战第22天】 在Java编程中,Lambda表达式和Stream API是两个强大的功能,它们极大地简化了代码的编写和提高了开发效率。本文将深入探讨这两个概念的基本用法、优势以及在实际项目中的应用案例,帮助读者更好地理解和运用这些现代Java特性。
|
13天前
|
搜索推荐 Java 数据库连接
Java|在 IDEA 里自动生成 MyBatis 模板代码
基于 MyBatis 开发的项目,新增数据库表以后,总是需要编写对应的 Entity、Mapper 和 Service 等等 Class 的代码,这些都是重复的工作,我们可以想一些办法来自动生成这些代码。
25 6