- 作用:
用于解决已有集合类库既有的弊端,可以将数组和集合转换为Stream流,再调用Stream流中的方法 - 传统的方式遍历集合:
package Stream;
import java.util.ArrayList;
import java.util.List;
public class Demo01 {
public static void main(String[] args) {
List<String> list = List.of("张无忌", "周芷若", "赵敏", "张强", "张三丰");
//筛选出姓张的,放入一个集合
ArrayList<String> listZhang = new ArrayList<>();
for (String i : list) {
if (i.startsWith("张")) {
listZhang.add(i);
}
}
//筛选出以上姓名长度为3的,放入一个集合
ArrayList<String> listlen3 = new ArrayList<>();
for (String i : listZhang) {
if (i.length()==3) {
listlen3.add(i);
System.out.println(i);
}
}
}
}
- Stream的更优写法:
package Stream;
import java.util.List;
public class Demo02 {
public static void main(String[] args) {
List<String> list = List.of("张无忌", "周芷若", "赵敏", "张强", "张三丰");
//筛选出姓张的,放入一个集合
//筛选出以上姓名长度为3的,放入一个集合
//打印输出
list.stream()//获取流、过滤姓张、过滤长度为3、逐一打印。
.filter(name->name.startsWith("张")) //filter内包含函数式接口Predicate<T>,可以筛选姓张的
.filter(namelen->namelen.length()==3) //filter内包含函数式接口Predicate<T>,可以筛选出以上姓名长度为3的
.forEach(name-> System.out.println(name));//forEach内包含函数式接口Consumer<T>
}
}
流式思想类似于工厂车间的“生产流水线”,对数据源(集合或者数组)一层一层的加工处理。
这里的 filter
、filter
、forEach
都是在对函数模型进行操作,集合元素并没有真正被处理。只有当终结方法 forEach
执行的时候,整个模型才会按照指定策略执行操作。而这得益于Lambda的延迟执行特性。可以避免性能浪费