Scala基础知识7

一,可变数组和不可变数组的转换方法:

不可变数组转换为可变数组使用 toBuffer 函数.

可变数组转换为不可变数组使用 toArray 函数。

转换过程中原始数组不会发生变化,而是返回一个新的数组。

二,多维数组

使用 Array of 函数创建多维数组,例如二维数组val arr = Array.ofDim[Double](3,4)表示三行四列的二维数组。

遍历二维数组使用嵌套的 for 循环,通过行索引和列索引访问和设置元素。

三,列表List

不可变 List

List 默认为不可变集合,不可变列表默认是有序且允许重复数据的,创建时使用 list关键字。

集合间合并:将一个整体拆成一个一个的个体,称为扁平化。空集合 Nil

可变ListBuffer

可变列表使用 listBuffer,添加数据有三种方式:+=、append,insert。

列表的合并是通过扁平化实现的,不会嵌套列表。

四,Set 集合

默认情况下, Scala 使用的是不可变集合, 如果你想使用可变集合, 需要引用

scala.collection.mutable.Set 包。

​​​​​​​不可变 Set

不可变集合使用 set关键字,数据无序且不允许重复,遍历集合使用 for 循环。

​​​​​​​可变 mutable.Set

可变集合使用 mutable.set,添加和删除元素会返回新的集合。

​​​​​​​五,Map 集合

Scala 中的 Map 和 Java 类似,也是一个散列表 ,它存储的内容也是键值对(key-value **)**映射。

​​​​​​​不可变 Map

不可变映射使用 map 关键字,存储键值对,数据无序。

​​​​​​​可变 Map

可变映射使用 mutable.Map,可以添加、删除和修改键值对。

访问数据使用 get方法,如果键不存在则返回默认值**。**

​​​​​​​六,元组
元组也是可以理解为一个容器,可以存放各种相同或不同类型的数据。说的简单点,就是将多个无关的数据封装为一个整体,称为元组。注意:元组中最大只能有 22 个元素。

​​​​​​​七,集合常用函数

基本属性和常见操作

​​​​​​​衍生集合

​​​​​​​集合计算简单函数

  1. sorted

对一个集合进行自然排序,通过传递隐式的Ordering

2.sortBy

对一个属性或多个属性进行排序,通过它的类型。

3.sortWith

基于函数的排序,通过一个 comparator 函数,实现自定义排序的逻辑。

集合计算高级函数

过滤:遍历一个集合并从中获取满足指定条件的元素组成一个新的集合。

​​​​​​​**转化 / 映射 map ****):******将集合中的每一个元素映射到某一个函数。

扁平化+映射 注:flatMap 相当于先进行 map 操作,在进行 flatten 操作集合中的每个元素的子元素映射到某个函数并返回新集合。

​​​​​​​分组 (group): 按照指定的规则对集合的元素进行分组。

Reduce 方法

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

Fold 方法

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

fold 基本使用

两个集合合并

相关推荐
朝新_2 小时前
【多线程初阶】阻塞队列 & 生产者消费者模型
java·开发语言·javaee
立莹Sir2 小时前
Calendar类日期设置进位问题
java·开发语言
XMYX-03 小时前
Spring Boot + Prometheus 实现应用监控(基于 Actuator 和 Micrometer)
spring boot·后端·prometheus
风逸hhh3 小时前
python打卡day46@浙大疏锦行
开发语言·python
火兮明兮4 小时前
Python训练第四十三天
开发语言·python
@yanyu6664 小时前
springboot实现查询学生
java·spring boot·后端
ascarl20105 小时前
准确--k8s cgroup问题排查
java·开发语言
酷爱码5 小时前
Spring Boot项目中JSON解析库的深度解析与应用实践
spring boot·后端·json
fpcc5 小时前
跟我学c++中级篇——理解类型推导和C++不同版本的支持
开发语言·c++
莱茵菜苗5 小时前
Python打卡训练营day46——2025.06.06
开发语言·python