1.什么事Stream流
stream流和Lambda表达式都是JAVA8的提出的新概念,em不是IO流的Stream,是一种使用函数式编程方式在集合类上进行操作的工具,使用Stream API对集合进行操作,以内部迭代的方式,非常的方便~又高效。(......注意!不是Steam是Stream!)
特点:
- 不是一种数据结构,不会存数据,只是在原数据集上定义了一组操作
- 这些操作是惰性的,即每当访问到流中的一个元素,才会在此元素上执行这一系列操作
- 因为不保存数据,故每个Stream流只能使用一次
2.创建Stream流
如果想使用Stream流来操作集合或数组,要先转换为Stream流,举个例子:
//数组转换Stream流
String[] strs = {"1","2","3","1"};
Stream<String> stream = Arrays.stream(strs);
//list集合转换Stream流
ArrayList<String> strings = new ArrayList<>();
Stream<String> stream1 = strings.stream();
转换为Stream流后就可以使用Stream中的方法对集合活数组进行操作了。
方法:
1.distinct()去重
2.limit()截取,可以用来分组
3.filter()通过条件过滤去,可以想sql一样做一些查询数据等操作,使用Lambda表达式
=====还有很多 不一一按说明了
直接看代码~ 我们先用数组测试一下Stream流里的几个方法
通过distinct()去重,并转换为List集合
List<String> distinct = Arrays.stream(strs).distinct().collect(Collectors.toList());//转换为List集合 [1,3,2]
通过limit(n)截取 可以使用skip(n)配合limitt(n)实现分页
List<String> collect1 = Arrays.stream(strs).limit(2).collect(Collectors.toList());//[1,3]
List<String> collect2 = Arrays.stream(strs).skip(2).limit(2).collect(Collectors.toList());//[2,1]
通过filter()配合Lambda表格式实现过滤操作
List<String> collect3 = Arrays.stream(strs).filter(s -> !s.equals("1")).collect(Collectors.toList());//[3,2]