scala的函数式编程的聚合操作

本文详细介绍了Scala中的聚合操作,包括reduce和fold方法。通过实例展示了如何使用这些方法来计算列表中所有元素的和,揭示了它们的工作原理和区别。
摘要由CSDN通过智能技术生成

聚合操作
聚合操作,可以将一个列表中的数据合并为一个。这种操作经常用来统计分析中
聚合 | Reduce
reduce表示将列表,传入一个函数进行聚合计
定义
方法签名
scala def reduce[A1 >: A](op: (A1, A1) ⇒ A1): A1
方法解析
| reduce方法 | API | 说明 | | ---------- | ----------------- | ------------------------------------------------------------ | | 泛型 | [A1 >: A] | (下界)A1必须是集合元素类型的子类 | | 参数 | op: (A1, A1) ⇒ A1 | 传入函数对象,用来不断进行聚合操作
第一个A1类型参数为:当前聚合后的变量
第二个A1类型参数为:当前要进行聚合的元素 | | 返回值 | A1 | 列表最终聚合为一个元素 |
reduce执行流程分析:
在这里插入图片描述
reduce和reduceLeft效果一致,表示从左到右计算
reduceRight表示从右到左计算

案例
定义一个列表,包含以下元素:1,2,3,4,5,6,7,8,9,10
使用reduce计算所有元素的和
参考代码
scala scala> val a = List(1,2,3,4,5,6,7,8,9,10)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值