Stream API学习
什么是 Stream?
Stream(流)是一个来自数据源的元素队列并支持聚合操作
- 元素是特定类型的对象,形成一个队列。 Java中的Stream并不会存储元素,而是按需计算。
- 数据源:Stream 的来源。 可以是集合,数组,I/O channel, 产生器generator 等。
- 聚合操作:类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。
1. 生成流
在 Java 8 中, 集合接口有两个方法来生成流:
-
stream() − 为集合创建串行流。
-
parallelStream() − 为集合创建并行流
List list = new ArrayList();
list.stream()
2. forEach() 方法
void forEach(Consumer<? super T> action);其实与集合类中的forEach方法一致
List<Integer> numbers = Arrays.asList(-1, -2, 0, 4, 5);
numbers.stream().forEach(n -> System.out.println("List element: " + n));
3.map() 方法
它是需要传入一个Function匿名对象,这个对象负责对每个元素(T)做计算操作,(结果类为R泛型)
<R> Stream<R> map(Function<? super T, ? extends R> mapper);
//使用map输出每个元素的绝对值大小
List<Integer> numbers = Arrays.asList(-1, -2, 0, 4, 5);
numbers.stream().map( n -> Math.abs(n)).forEach(n -> System.out.println("Element abs: " + n));
//使用map输出每个元素的平方值
List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
List<Integer> squaresList = numbers.stream().map( i -> i*i).distinct().collect(Collectors.toList());
4.filter() 方法
/*filter 方法*/
Stream<T> filter(Predicate<? super T> predicate);
/*Predicate接口*/
@FunctionalInterface
public interface Predicate<T> {
boolean test(T t);
那么我们可以知道,他就是把每个元素传入test方法去验证,而test方法又由我们来用lambda表达式实现
List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
// 获取空字符串的数量
long count = strings.stream().filter(string -> string.isEmpty()).count();
5.limit() 方法
limit 方法用于获取指定数量的流。
//以下代码片段使用 limit 方法打印出 10 条数据:
Random random = new Random();
random.ints().limit(10).forEach(System.out::println);
6.sort() 方法
Stream<T> sorted();
Stream<T> sorted(Comparator<? super T> comparator);
7.collect()方法 (将流转为数据源 (集合等))
参数为一个java.util.stream.Collector类型对象,可以用java.util.stream.Collectors工具类提供的静态方法来生成,Collectors类实现很多的归约操作,如Collectors.toList()、Collectors.toSet()、Collectors.joining()(joining适用于字符串流)等
List<Integer> numbers = Arrays.asList(-1, -2, 0, 4, 5);
List<Integer> abss = numbers.stream().map( n -> Math.abs(n)).collect(Collectors.toList());
System.out.println("Abs list: " + abss);