前言
Java Stream 是一种强大的数据处理工具,可以帮助开发人员快速高效地处理和转换数据流。使用 Stream 操作可以大大简化代码,使其更具可读性和可维护性,从而提高开发效率。本文将为您介绍 Java Stream 操作的所有方面,包括 range、range、iterate、generate 等操作,让你的代码行云流水,更加优雅。
- range():生成一个包含指定范围内所有整数的 Stream。
- rangeClosed():生成一个包含指定范围内所有整数(包括端点)的 Stream。
- iterate():根据指定的初始值和 UnaryOperator 生成一个无限长度的 Stream。
- generate():根据指定的 Supplier 生成一个无限长度的 Stream。
- takeWhile():返回满足指定条件的元素,直到遇到第一个不满足条件的元素。
- dropWhile():返回不满足指定条件的元素,直到遇到第一个满足条件的元素。
- peek():对每个元素执行指定的操作,但并不消费元素。
- boxed():将 Stream 中的基本类型元素装箱成对应的包装类型。
- parallel():返回一个并行的 Stream。
- sequential():返回一个顺序的 Stream。
示例
1. 使用 range():生成一个包含指定范围内所有整数的 Stream。
代码示例:
import java.util.stream.IntStream;
public class RangeExample {
public static void main(String[] args) {
IntStream.range(1, 6)
.forEach(System.out::println);
}
}
输出结果:
1
2
3
4
5
2. 使用 rangeClosed():生成一个包含指定范围内所有整数(包括端点)的 Stream。
代码示例:
import java.util.stream.IntStream;
public class RangeClosedExample {
public static void main(String[] args) {
IntStream.rangeClosed(1, 5)
.forEach(System.out::println);
}
}
输出结果:
1
2
3
4
5
3. 使用 iterate():根据指定的初始值和 UnaryOperator 生成一个无限长度的 Stream。
代码示例:
import java.util.stream.Stream;
public class IterateExample {
public static void main(String[] args) {
Stream.iterate(2, n -> n * 2)
.limit(5)
.forEach(System.out::println);
}
}
输出结果:
2
4
8
16
32
4. 使用 generate():根据指定的 Supplier 生成一个无限长度的 Stream。
代码示例:
import java.util.Random;
import java.util.stream.Stream;
public class GenerateExample {
public static void main(String[] args) {
Stream.generate(() -> new Random().nextInt(100))
.limit(5)
.forEach(System.out::println);
}
}
输出结果:
64
77
41
21
73
5. 使用 takeWhile():返回满足指定条件的元素,直到遇到第一个不满足条件的元素。
代码示例:
import java.util.stream.Stream;
public class TakeWhileExample {
public static void main(String[] args) {
Stream.of("apple", "banana", "orange", "pear")
.takeWhile(s -> s.startsWith("a"))
.forEach(System.out::println);
}
}
输出结果:
apple
6. 使用 dropWhile():返回不满足指定条件的元素,直到遇到第一个满足条件的元素。
代码示例:
import java.util.stream.Stream;
public class DropWhileExample {
public static void main(String[] args) {
Stream.of("apple", "banana", "orange", "pear")
.dropWhile(s -> s.startsWith("a"))
.forEach(System.out::println);
}
}
输出结果:
banana
orange
pear
7. 使用 peek():对每个元素执行指定的操作,但并不消费元素。
代码示例:
import java.util.stream.Stream;
public class PeekExample {
public static void main(String[] args) {
Stream.of("apple", "banana", "orange", "pear")
.peek(System.out::println)
.count();
}
}
输出结果:
apple
banana
orange
pear
8. 使用 boxed():将 Stream 中的基本类型元素装箱成对应的包装类型。
代码示例:
import java.util.stream.IntStream;
public class BoxedExample {
public static void main(String[] args) {
IntStream.range(1, 6)
.boxed()
.forEach(System.out::println);
}
}
输出结果:
1
2
3
4
5
9. 使用 parallel():返回一个并行的 Stream。
代码示例:
import java.util.stream.Stream;
public class ParallelExample {
public static void main(String[] args) {
Stream.of("apple", "banana", "orange", "pear")
.parallel()
.forEach(System.out::println);
}
}
输出结果:
pear
banana
apple
orange
10. 使用 sequential():返回一个顺序的 Stream。
代码示例:
import java.util.stream.Stream;
public class SequentialExample {
public static void main(String[] args) {
Stream.of("apple", "banana", "orange", "pear")
.parallel()
.sequential()
.forEach(System.out::println);
}
}
输出结果:
apple
banana
orange
pear
结尾
如果觉得对你有帮助,可以多多评论,多多点赞哦,也可以到我的主页看看,说不定有你喜欢的文章,也可以随手点个关注哦,谢谢。
我是不一样的科技宅,每天进步一点点,体验不一样的生活。我们下期见!
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net