学习java8新特性 stream流中reduce()方法是如何求和的
2021-07-26 09:36:13
浏览数 (6430)
本篇文章将和大家介绍 java8 中的一个新特性,关于 stream 流中的 reduce() 方法的具体使用方法,主要包括单参数的单字段求和和双参数的多字段求和两种方法。本文供大家学习参考,下面是详细内容。
1.stream().reduce()单字段求和
(1)普通数字求和
public static void test2(){
List<Integer> list= Arrays.asList(new Integer[]{1,2,3,4,5,6,7,8,9});
Integer sum=list.stream().reduce((x,y)->x+y).get();
System.out.println(sum);
}
(2)BigDecimal求和
public static void main(String[] args) {
List<User> list=new ArrayList<>();
User user1=new User();
user1.setNum1(new BigDecimal(123));
user1.setNum2(new BigDecimal(100));
list.add(user1);
User user2=new User();
user2.setNum1(new BigDecimal(100));
user2.setNum2(new BigDecimal(100));
list.add(user2);
BigDecimal sum=list.stream().map(User::getNum1).reduce(BigDecimal::add).get();
System.out.println(sum);
}
结果:
但是如果列表是中没有数据list.size()==0的时候会报错,所以需要将代码修改成如下:
BigDecimal sum=list.stream()
.map(User::getNum1) //返回num1的列表
.reduce(BigDecimal.ZERO,BigDecimal::add); //列表字段求和
当list中没有元素的时候就默认返回0;
2.stream().reduce()多字段求和
public static void main(String[] args) {
List<User> list=new ArrayList<>();
User user1=new User();
user1.setNum1(new BigDecimal(123));
user1.setNum2(new BigDecimal(100));
list.add(user1);
User user2=new User();
user2.setNum1(new BigDecimal(100));
user2.setNum2(new BigDecimal(100));
list.add(user2);
User u=list.stream().reduce((x,y)->{
User user=new User();
user.setNum1(x.getNum1().add(y.getNum1()));
user.setNum2(x.getNum2().add(y.getNum2()));
return user;
}).get();
System.out.println(u.getNum1()+"------------"+u.getNum2());
}
结果:
同样,如果list中没有元素,则使用如下方式:
User u=list.stream().reduce(new User(),(x,y)->{
User user=new User();
user.setNum1(x.getNum1().add(y.getNum1()));
user.setNum2(x.getNum2().add(y.getNum2()));
return user;
});
默认给一个User对象,就不会报错。
总结
有三个参数类型,本文只说了前两个
1.一个参数:Optional reduce(BinaryOperator accumulator),传入求和函数式,
2.两个参数:T reduce(T identity, BinaryOperator accumulator),(默认值,求和函数式)
3.三个参数的没怎么用过,暂不说明
到此本篇关于学习 java8 新特性,stream 流中 reduce() 求和的具体方法总结的文章就介绍到这了,想要了解更多相关java reduce()求和方法的其他内容请搜索W3Cschool以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!