Scala总结(八)

集合(三)

集合常用函数

集合计算高级函数

  1. 过滤:遍历一个集合并从中获取满足指定条件的元素组成一个新的集合
  2. 转化/映射:将集合中的每一个元素映射到某一个函数
  3. 扁平化
  4. 分组:按照指定的规则对集合的元素进行分组
  5. 简化(归约)
  6. 折叠

实例:

运行结果:

Reduce方法

Reduce 简化(归约) :通过指定的逻辑将集合中的数据进行聚合,从而减少数据,最终获取结果

实例:

运行结果:

Fold 方法

Fold 折叠:化简的一种特殊情况

实例:

运行结果:

两个集合合并

运行结果:

普通WordCount 案例

要求:单词计数:将集合中出现的相同的单词,进行计数,取计数排名前三的结果

实例:

运行结果:

复杂 WordCount 案例

方式一(不通用)

实例:

运行结果:

队列

Scala 也提供了队列(Queue)的数据结构,队列的特点就是先进先出。进队和出队的方法分别为 enqueue 和dequeue

实例:

运行结果:

并行集合

Scala 为了充分使用多核 CPU,提供了并行集合(有别于前面的串行集合),用于多核环境的并行计算

实例:

运行结果:

相关推荐
灰子学技术12 分钟前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
二十雨辰37 分钟前
[python]-AI大模型
开发语言·人工智能·python
Yvonne爱编码1 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚1 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂1 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
pas1361 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
Gogo8161 小时前
BigInt 与 Number 的爱恨情仇,为何大佬都劝你“能用 Number 就别用 BigInt”?
后端
fuquxiaoguang1 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
琹箐1 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
Monly212 小时前
Java:修改打包配置文件
java·开发语言