Java8的Stream中的Collectors操作求double类型和的坑

Java8的Stream中的Collectors操作求double类型和的坑

无敌踩坑王的我又双叒叕来了!!!!!!

例子:

    @Test
    public void testSumDouble() {
   
        double a = 0.001;
        double b = 0.002;
        double c = 0.004;

        List<Double> doubleList = new ArrayList<>();
        doubleList.add(a);
        doubleList.add(b);
        double sum = doubleList.stream().collect(Collectors.summarizingDouble(Double::shortValue)).getSum();
        System.out.println(sum);
        if (c > sum) {
   
            System.out.println("sum:" + sum + "小于" + "c:" + c);
        }

    }

一、场景,统计double类型的数值进行计算

二、计算

感觉这个结果应该是什么样子的?

是不是应该输出的是小于的

是的,输出的就是小于的,但是值确是这样的

0.0
sum:0.0小于c:0.004

是不是与预期的不符?

接下来我们看一下他的底层的定义

 	计算用的方法

	Collectors.summarizingDouble(Double::shortValue)
    
    summarizingDouble实现的方法
        
    public static <T>
    Collector<T, ?, DoubleSummaryStatistics> summarizingDouble(ToDoubleFunction<? super T> mapper) {
   
        return new CollectorImpl<T, DoubleSummaryStatistics, DoubleSummaryStatistics>(
                DoubleSummaryStatistics::new,
                (r, t) -> r.accept(mapper.applyAsDouble(t)),
                (l, r) -> {
    l.combine(r); return l; }, CH_ID);
    }

DoubleSummaryStatistics 类的代码

/*
 * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
 * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 */
package java.util;

import 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Java 8引入了Stream API,有许多新方法,其有一个对于分组和聚合操作非常有用,那就是groupingBy()方法。它可以将一个流分组成一个Map,其Entry的key是分组的条件,value是分组的结果,通常是一个List或其他集合。groupingBy()方法的另一个形式是groupingByConcurrent(),它返回一个并发Map,对于并发访问更加友好。 利用groupingBy()方法进行多字段分组和操作的示例如下: 假设有一个Person类,其包含属性:name, age和salary。现在我们需要根据name和age两个字段进行分组,并出每组的salary总和。可以使用groupingBy()方法加上summingDouble()方法来实现: ``` List<Person> persons = Arrays.asList( new Person("Tom", 20, 5000), new Person("Tom", 21, 4000), new Person("Jerry", 22, 6000), new Person("Jerry", 23, 5500), new Person("Kate", 24, 7000), new Person("Kate", 25, 8000) ); Map<String, Map<Integer, Double>> result = persons.stream() .collect(Collectors.groupingBy(Person::getName, Collectors.groupingBy(Person::getAge, Collectors.summingDouble(Person::getSalary)))); ``` 这里的personList是一个包含了6个Person对象的List,我们希望将其相同name和age的对象分组,得salary的总和。在groupingBy()方法,第一个参数是分组条件,这里是Person::getName,第二个参数是分组的结果,这里是一个嵌套的groupingBy()方法,用于再次按照age进行分组,结果是一个Map<Integer, Double>。最后,我们使用summingDouble()方法对salary字段进行和,得到各个分组的salary总和。这里的result是一个Map<String, Map<Integer, Double>>类型的对象,其key是name,value是以age为key,salary总和为value的子Map,就是我们需要的结果。 这样,我们就利用Java 8Stream API和groupingBy()方法进行了多字段分组和操作,代码简洁,可读性强,非常方便。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值