Double数据精度导致的问题

早知道double的数据精度有限,所以在计算金钱等精细数据的时候,要用bigdecimal;

但是最近在计算一些客流量数据数据的时候,也发现,这种数据精度不足的情况,会不仅仅导致小数点级的计算结果出错

实在是,该踩得坑的都得踩一遍

经验就是:可以分页查询,但是不要分页计算

java 复制代码
public static void main(String[] args) {

        ArrayList<Double> doubles = new ArrayList<>();
        doubles.add(100.0);
        doubles.add(200.0);
        doubles.add(300.0);
        doubles.add(400.0);
        doubles.add(500.0);
        doubles.add(600.0);
        doubles.add(700.0);
        doubles.add(800.0);
        doubles.add(900.0);
        doubles.add(1000.0);

        int pageSize = 3;
        // 计算总页数
        int totalPage = (doubles.size() + pageSize - 1) / pageSize;
        List<Double> averageUvListForSum = new ArrayList<>();
        for (int pageNum = 0; pageNum < totalPage; pageNum++) {
            // 计算当前页的开始索引
            int fromIndex = (pageNum) * pageSize;
            // 防止结束索引超出数组长度
            int toIndex = Math.min(fromIndex + pageSize, doubles.size());
            List<Double> doubles1 = doubles.subList(fromIndex, toIndex);
            Double averageUvByPage = doubles1.stream().mapToDouble(Double::doubleValue).average().orElse(0.0);
            //分页计算,从数学上是行的通的,但是计算机的double精度会导致计算错误
            Double averageUvForSum = (averageUvByPage)/(doubles.size()/(toIndex - fromIndex));
            averageUvListForSum.add(averageUvForSum);
        }
        //分页计算平平均值
        double sum = averageUvListForSum.stream().mapToDouble(Double::doubleValue).sum();//600.0
        //Stream计算平均值
        double v = doubles.stream().mapToDouble(Double::doubleValue).average().orElse(0.0);//550.0
    }
相关推荐
仰泳之鹅5 分钟前
【杂谈】C语言中的链接属性、声明周期以及static关键字
java·c语言·前端
weixin_531651817 分钟前
Java 正则表达式
java·正则表达式
空空kkk8 分钟前
Spring Boot项目的搭建
java·spring boot·后端
2501_940315268 分钟前
【无标题】(leetcode933)最近的请求次数
java·前端·javascript
Sheep Shaun12 分钟前
深入理解红黑树:从概念到完整C++实现详解
java·开发语言·数据结构·c++·b树·算法
每天学习一丢丢12 分钟前
Spring Boot 调用泛微 E9 Token 认证 + 创建流程完整教程
java·spring boot·后端
苦逼的老王16 分钟前
《java-使用kkview+libreoffice 实现在线预览ppt、xls、doc、pdf..》
java·pdf·powerpoint
没有bug.的程序员18 分钟前
Spring Boot 启动原理:从 @SpringBootApplication 到自动配置深度解析
java·spring boot·后端·python·springboot·application
jiaguangqingpanda18 分钟前
Day26-20260122
java·算法·排序算法
Ahtacca20 分钟前
拒绝重复造轮子:利用自定义注解封装POI,实现Java通用Excel解析
java·javascript·vue·excel