开发避坑指南(46):Java Stream 对List的BigDecimal字段进行求和

需求

对int,long类型的数据求和直接用stream().mapToInt()、stream().mapToDouble(),可是没有stream().mapToBigDecimal()这样的方法,那么如何用stream对List的BigDecimal字段进行求和?

代码实现

直接上代码

java 复制代码
public class OrderInfo {
    private BigDecimal fee;
}

public class ListTest2 {
    public static void main(String[] args) {
        OrderInfo orderInfo = new OrderInfo();
        orderInfo.setFee(new BigDecimal(10));
        OrderInfo orderInfo2 = new OrderInfo();
        orderInfo2.setFee(new BigDecimal(20));

        List<OrderInfo> list1 = new ArrayList<>();
        list1.add(orderInfo);
        list1.add(orderInfo2);

        BigDecimal ret = list1.stream().map(e -> e.getFee()).reduce(BigDecimal::add).get();
        System.out.println(ret.intValue());
    }
}

输出结果是30。

语法说明

(1).stream()表示返回一个以本集合为数据源的顺序流。

(2).map()表示对流中的每个元素执行‌映射转换‌,生成新元素组成的新流。代码中的意思是提取流中每个元素的fee属性,将其映射为BigDecimal类型的流。

(3).reduce() 表示 Java Stream API 中的‌终止操作‌,其核心作用是将流中的元素合并为单个结果。代码中的意思是使用BigDecimal的add方法进行归约求和,返回Optional。

(4).get()‌方法表示从Optional中获取最终计算结果。

相关推荐
皮皮林5518 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河9 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程11 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅13 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者14 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺14 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart15 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP16 小时前
MyBatis-mybatis入门与增删改查
java
孟陬20 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端