一、什么是 Stream
Stream 中文称为 “流”,通过将集合转换为这么一种叫做 “流” 的元素序列,通过声明性方式,能够对集合中的每个元素进行一系列并行或串行的流水线操作。换句话说,你只需要告诉流你的要求,流便会在背后自行根据要求对元素进行处理,而你只需要 “坐享其成”。
二、流操作
数据源->流->中间操作->终端操作
三、流与集合
对集合进行修改处理,使用的是外部迭代,而流使用的是内部迭代。流和迭代器类似,只能迭代一次
Stream stream = list.stream().map(Person::getName).sorted().limit(10);
List newList = stream.collect(Collectors.toList());
List newList2 = stream.collect(Collectors.toList());
上面代码中第三行会报错,因为第二行已经使用过这个流,这个流已经被消费掉了。
四、一般方法
4.1、 stream() / parallelStream()
最常用到的方法,将集合转换为流
List list = new ArrayList();
list.stream();
parallelStream() 是并行流方法,能够让数据集执行并行操作
4.2、filter(T -> boolean)
保留 boolean 为 true 的元素
//保留年龄为 20 的 person 元素
list = list.stream()
.filter(person -> person.getAge() == 20)
//.filter(String -> String.equals(“sss”))
//.filter(Integer -> Integer==1)
.collect(Collectors.toList());
//打印输出 [Person{name=‘jack’, age=20}]
collect(toList()) 可以把流转换为 List 类型
4.3、distinct()
去除重复元素,这个方法是通过类的 equals 方法来判断两个元素是否相等的
如例子中的 Person 类,需要先定义好 equals 方法(重写equals方法),不然类似
[Person{name=‘jack’, age=20}, Person{name=‘jack’, age=20}]这样的情况是不会处理的。
List list = Arrays.asList(2,4,1,7,5,4,6,9,10);
list.sort((a, b) -> a.compareTo(b.intValue()));
list = list.stream() .distinct().collect(Collectors.toList());
4.4、sorted() / sorted((T, T) -> int)
list = list.s
Java-Stream流式编程
最新推荐文章于 2023-02-10 21:00:00 发布