常用操作
创建流
1.单列集合: 集合对象.stream()
List<Author> authors = getAuthors();
Stream<Author> stream = authors.stream();
2.数组:Arrays.stream(数组)
或者使用Stream.of
来创建
Integer[] arr = {1,2,3,4,5};
Stream<Integer> stream = Arrays.stream(arr);
Stream<Integer> stream2 = Stream.of(arr);
3.双列集合:转换成单列集合后再创建
Map<String,Integer> map = new HashMap<>();
map.put("大蛇丸",18);
map.put("纲手",16);
map.put("自来也",17);
Stream<Map.Entry<String, Integer>> stream = map.entrySet().stream();
中间操作
1.filter
可以对流中的元素进行条件过滤,符合过滤条件的才能继续留在流中。
2.map
可以把对流中的元素进行计算或转换。
3.distinct
可以去除流中的重复元素。
distinct方法是依赖Object的equals方法来判断是否是相同对象的。所以需要注意重写equals方法。
4.sorted
可以对流中的元素进行排序。
如果调用空参的sorted()方法,需要流中的元素是实现了Comparable。
5.limit
可以设置流的最大长度,超出的部分将被抛弃。
6.skip
跳过流中的前n个元素,返回剩下的元素
7.flatMap
map只能把一个对象转换成另一个对象来作为流中的元素。而flatMap可以把一个对象转换成多个对象作为流中的元素。
终结操作
1.forEach
对流中的元素进行遍历操作,我们通过传入的参数去指定对遍历到的元素进行什么具体操作。
2.count
可以用来获取当前流中元素的个数。
3.max&min
可以用来或者流中的最值。
4.collect
把当前流转换成一个集合。
查找与匹配
1.anyMatch
可以用来判断是否有任意符合匹配条件的元素,结果为boolean类型。
2.allMatch
可以用来判断是否都符合匹配条件,结果为boolean类型。如果都符合结果为true,否则结果为false。
3.noneMatch
可以判断流中的元素是否都不符合匹配条件。如果都不符合结果为true,否则结果为false
4.findAny
获取流中的任意一个元素。该方法没有办法保证获取的一定是流中的第一个元素。
5.findFirst
获取流中的第一个元素。
reduce归并
对流中的数据按照你指定的计算方式计算出一个结果。(缩减操作)
reduce的作用是把stream中的元素给组合起来,我们可以传入一个初始值,它会按照我们的计算方式依次拿流中的元素和初始化值进行计算,计算结果再和后面的元素计算。
其中identity就是我们可以通过方法参数传入的初始值,accumulator的apply具体进行什么计算也是我们通过方法参数来确定的。
注意事项
- 惰性求值(如果没有终结操作,没有中间操作是不会得到执行的)
- 流是一次性的(一旦一个流对象经过一个终结操作后。这个流就不能再被使用)
- 不会影响原数据(我们在流中可以多数据做很多处理。但是正常情况下是不会影响原来集合中的元素的。这往往也是我们期望的)