0.stream流
Java8API添加了一个新的抽象称为流Stream,将要处理的元素集合看作一种流, 流在管道中传输,能够对每个元素
进行一系列并行或串行的流水线操作。
data:image/s3,"s3://crabby-images/04b73/04b73cca998664910e0d2a15ebdd534be8487b90" alt=""
1.常用方法
我们创建实体类:
public class Students{ String name; //姓名 Integer age; //年龄 Double math; //数学成绩 Double chinese; //语文成绩 String birthday; //生日 }
假设生成的数据如下:
data:image/s3,"s3://crabby-images/a57d5/a57d581552cff32bbaba38e94e230cae8413c0ad" alt=""
(1)filter(element -> boolean表达式)
作用:过滤元素,符合Boolean表达式的留下来
例子1:
List<Students> data= studentsList.stream().filter(s->s.getMath()>90).collect(Collectors.toList());
data:image/s3,"s3://crabby-images/f2e78/f2e781b9fb54b9327d190fe4731766e5eb7427b4" alt=""
我们也可以多次筛选,比如除了上面的条件,我们再加入筛选判断大于等于18岁的人。
List<Students> data= studentsList.stream().filter(s->s.getMath()>90).filter(x->x.getAge()>=18).collect(Collectors.toList());
data:image/s3,"s3://crabby-images/e5202/e52022e24c52f504dbee58cf43221fbfe805d2a1" alt=""
(2)distinct 去重
distinct使用了hashCode()和equals()方法来获取不同元素。
基础用法:
studentsList.stream().distinct().collect(Collectors.toList())
上面这个用法可以整体进行去重。
如何需要根据某个字段进行去重?我们可以使用collectingAndThen
List<Students> data= studentsList.stream().collect(
Collectors.collectingAndThen(
Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(Students::getAge))), ArrayList::new
));
data:image/s3,"s3://crabby-images/e3d26/e3d26242abb44dbf11228b7e98a4eecdbcadd41b" alt=""
上面的结论可以看到,我们根据age这个属性进行了去重。
(3)sort 排序
假如我们要根据数学成绩进行排序
List<Students> data= studentsList.stream()
.sorted(Comparator.comparingDouble(Students::getMath))
.collect(Collectors.toList());
data:image/s3,"s3://crabby-images/3d69d/3d69dcc483048f168060814c8ffdf5b6c025f453" alt=""
comparingDouble是比较的Double类型,如果需要可以改成comparingInt类型。
(4)limit 返回前n个元素
List<Students> data= studentsList.stream()
.limit(1)
.collect(Collectors.toList());
data:image/s3,"s3://crabby-images/a52a0/a52a09cda3909bcc989798f05c42111eacc5dadf" alt=""
(5)skip 去除前n个元素
- 去除前n个元素
- limit(m).skip(n),先返回前m个元素,再从这m个元素中去除n个
- skip(n).limit(m),先去除n个元素,再返回剩余的前m个
data:image/s3,"s3://crabby-images/db2fc/db2fcb781f60bae58a5d8ac68e283ca9a336e79b" alt=""
可以看出,去除了前1个,剩余了三个。
(6)map
map作用就是针对管道流中的每一个数据元素进行转换操作。
假如我们需要修改每个人的数学成绩,将数学成绩翻倍
List<Students> data= studentsList.stream()
.map(x->{
x.setMath(x.getMath()*2);
return x;
})
.collect(Collectors.toList());
data:image/s3,"s3://crabby-images/4a858/4a858bfea919f6bee05e4b2893fb094452a79156" alt=""
我们也可以把数据按照某个属性组成一个新的集合。
List<String> data= studentsList.stream()
.map(Students::getName)
.collect(Collectors.toList());
data:image/s3,"s3://crabby-images/0c45c/0c45cb48c14bb963ac8a6859784c0f8048ae6efd" alt=""
(7)anyMatch
判断流中是否有元素满足这个Boolean表达式
boolean flag=false;
flag = studentsList.stream().anyMatch(x -> x.getAge() == 18);
data:image/s3,"s3://crabby-images/a9ff8/a9ff887b58db11c1b7dc3708e99d230a492ed255" alt=""
(8)allMatch
- allMatch(T -> boolean)即流中所有元素是否都满足Boolean条件
- noneMatch(T -> boolean)即是否流中没有一个元素满足Boolean表达
(9)count()
返回流中元素的个数,返回Long型
data:image/s3,"s3://crabby-images/78372/78372b40c4bd8f00d27fb54272e431cd1c2f71af" alt=""
(10)reduce
reduce操作将二进制运算符应用于流中的每个元素,其中运算符的第一个参数是前一个应用程序的返回值,第二个参数是当前流元素。
一共有三种用法:
Optional<T> reduce(BinaryOperator<T> accumulator);
T reduce(T identity, BinaryOperator<T> accumulator);
<U> U reduce(U identity,
BiFunction<U, ? super T, U> accumulator,
BinaryOperator<U> combiner)
例子:
int sum1 = studentsList.stream().map(Students::getAge).reduce(0, (a, b) -> a + b); //求和
int sum2 = studentsList.stream().map(Students::getAge).reduce(0, Integer::sum); //求和
Double max=studentsList.stream().map(Students::getMath).reduce(studentsList.get(0).getMath(), Double::max); //求数学的最大值
Double min=studentsList.stream().map(Students::getMath).reduce(studentsList.get(0).getMath(), Double::min); //求数学的最小值
data:image/s3,"s3://crabby-images/f9873/f98732d272695cebbd2441d7d2609a8e431c7b3d" alt=""
(11)forEach
- 处理集合时不能使用break和continue中止循环
- 可以使用
关键字return
跳出本次循环,并执行下一次遍历 - 不能跳出整个流的forEach循环
studentsList.stream().forEach((x)->{
System.out.println(x.getName());
}
);
2.Collect收集方法
收集流中元素的方法,传参是一个收集器接口, 常用写法:
.collect(Collectors.toList())收集到list集合
.collect(Collectors.toMap(x,x,x))收集到map集合
.collect(Collectors.groupingBy(xx))分组
.collect(Collectors.counting())统计集合总数
.collect(joining())连接字符串