Scala - 序列

Posted 大军

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Scala - 序列相关的知识,希望对你有一定的参考价值。

scala的集合也分为不可变集合和可变集合。集合包括序列Seq、集合Set、映射Map,这几个也是分为不可变和可变的。

不可变List

定义List,包括List的apply、:: Nil、以及:::来定义。
Nil是空的集合,::是head元素和tail列表组成一个新的列表,而且这个是从后面开始计算的,所以下面的也相对于3::Nil先计算,然后是2::(3 :: Nil),最后是1::(2::(3 :: Nil))。
如果head是一个List,那用::的话,第一个元素还是List,所以要用:::来形成新的列表,可以看看下面的list3、list4。

// 定义List
val list1: List[Int] = List(1, 2, 3)
val list2: List[Int] = 1 :: 2 :: 3 :: Nil
val list3: List[Any] = list1 :: list2
val list4: List[Int] = list1 ::: list2
println(list1) // List(1, 2, 3)
println(list2) // List(1, 2, 3)
println(list3) // List(List(1, 2, 3), 1, 2, 3)
println(list4) // List(1, 2, 3, 1, 2, 3)a

读取List:

// 取指定位置
println(list1(0)) // 1
// 取第一个无素
println(list1.head) // 1
// 取第一个无素后的剩余列表
println(list1.tail) // List(2, 3)
// 取第二个无素
println(list1.tail.head) // 2
// 取最后一个无素
println(list1.last) // 3
// 取最后一个无素后的剩余列表
println(list1.init) //  List(1, 2)
// 倒序
println(list1.reverse) //  List(3, 2, 1)
// 获取前N个元素
println(list1.take(2)) // List(1, 2)
// 字符串拼接
println(list1.mkString("-")) // 1-2-3

新增元素:

// 前面加元素
val list5_1 = list1.+:(100)
println(list5_1) // List(100, 1, 2, 3)
val list5_2 = 100 +: list1
println(list5_2) // List(100, 1, 2, 3)
val list5_3 = 100 :: list1
println(list5_3) // List(100, 1, 2, 3)
val list5_4 = list1.::(100)
println(list5_4) // List(100, 1, 2, 3)
// 后面加元素
val list6_1 = list1.:+(4)
println(list6_1) // List(1, 2, 3, 4)
val list6_2 = list1 :+ 4
println(list6_2) // List(1, 2, 3, 4)

遍历的同数组,这里不做演示。

可变ListBuffer

定义ListBuffer

// 定义ListBuffer
val list1: ListBuffer[Int] = ListBuffer()
val list2: ListBuffer[Int] = ListBuffer(1, 2, 3)
println(list1) // ListBuffer()
println(list2) // ListBuffer(1, 2, 3)

读取ListBuffer,同上。
修改指定元素:

list2(0) = 11
println(list2) // ListBuffer(11, 2, 3)
list2.update(0, 1)
println(list2) // ListBuffer(1, 2, 3)

新增元素:

// 后面加元素
list2.+=(4)
println(list2) // ListBuffer(1, 2, 3, 4)
list2 += 5
println(list2) // ListBuffer(1, 2, 3, 4, 5)
list2.append(6)
println(list2) // ListBuffer(1, 2, 3, 4, 5, 6)
// 前面加元素
list2.prepend(100)
println(list2) // ListBuffer(100, 1, 2, 3, 4, 5, 6)
// 指定位置加元素
list2.insert(1, 101)
println(list2) // ListBuffer(100, 101, 1, 2, 3, 4, 5, 6)

删除元素,这里类似数组

list2.remove(0)
println(list2) // ListBuffer(101, 1, 2, 3, 4, 5, 6)
list2.remove(1, 3)
println(list2) // ListBuffer(101, 4, 5, 6)
list2 -= 4
println(list2) // ListBuffer(101, 5, 6)

遍历的同数组,这里不做演示。

以上是关于Scala - 序列的主要内容,如果未能解决你的问题,请参考以下文章

总结scala中每个序列的连续值

Scala模式匹配错误,“错误的简单模式:错误使用_ *(不允许序列模式)”

对列表以外的序列进行 Scala 模式匹配

任务在 Databricks 上的 Scala 中不可序列化

Spark Scala:任务不可序列化错误

Scala Spark - 任务不可序列化