在 Scala 中,如果你需要一个长度不变的数组,可以使用 Array。但需要注意以下两点:
在 Scala 中使用
(index)
而不是
[index]
来访问数组中的元素,因为访问元素,对于 Scala 来说是方法调用,
(index)
相当于执行了
.apply(index)
方法。
Scala 中的数组与 Java 中的是等价的,
Array[Int]()
在虚拟机层面就等价于 Java 的
int[]
。
scala> val nums=new Array[Int](10)
nums: Array[Int] = Array(0, 0, 0, 0, 0, 0, 0, 0, 0, 0)
scala> val strings=new Array[String](10)
strings: Array[String] = Array(null, null, null, null, null, null, null, null, null, null)
scala> val a=Array("hello","scala")
a: Array[String] = Array(hello, scala)
scala> a(0)
res3: String = hello
复制代码
二、变长数组
在 scala 中通过 ArrayBuffer 实现变长数组 (又称缓冲数组)。在构建 ArrayBuffer 时必须给出类型参数,但不必指定长度,因为 ArrayBuffer 会在需要的时候自动扩容和缩容。变长数组的构建方式及常用操作如下:
import scala.collection.mutable.ArrayBuffer
object ScalaApp {
def main(args: Array[String]): Unit = {
val ab = new ArrayBuffer[Int]()
ab += 1
ab += (2, 3, 4)
ab ++= Array(5, 6, 7)
println(ab)
ab.trimEnd(3)
ab.insert(1, 8, 9)
ab.remove(2, 3)
val abToA = ab.toArray
println(abToA)
val aToAb = abToA.toBuffer
复制代码
需要注意的是:使用
+=
在末尾插入元素是一个高效的操作,其时间复杂度是 O(1)。而使用
insert
随机插入元素的时间复杂度是 O(n),因为在其插入位置之后的所有元素都要进行对应的后移,所以在
ArrayBuffer
中随机插入元素是一个低效的操作。
三、数组遍历
object ScalaApp extends App {
val a = Array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
for (elem <- a) {
print(elem)
for (index <- 0 until a.length) {
print(a(index))
for (index <- a.indices) {
print(a(index))
for (index <- a.indices.reverse) {
print(a(index))
复制代码
这里我们没有将代码写在 main 方法中,而是继承自 App.scala,这是 Scala 提供的一种简写方式,此时将代码写在类中,等价于写在 main 方法中,直接运行该类即可。
四、数组转换
数组转换是指由现有数组产生新的数组。假设当前拥有 a 数组,想把 a 中的偶数元素乘以 10 后产生一个新的数组,可以采用下面两种方式来实现:
object ScalaApp extends App {
val a = Array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
val ints1 = for (elem <- a if elem % 2 == 0) yield 10 * elem
for (elem <- ints1) {
println(elem)
val ints2 = a.filter(_ % 2 == 0).map(_ * 10)
for (elem <- ints1) {
println(elem)
复制代码
五、多维数组
和 Java 中一样,多维数组由单维数组组成。
object ScalaApp extends App {
val matrix = Array(Array(11, 12, 13, 14, 15, 16, 17, 18, 19, 20),
Array(21, 22, 23, 24, 25, 26, 27, 28, 29, 30),
Array(31, 32, 33, 34, 35, 36, 37, 38, 39, 40))
for (elem <- matrix) {
for (elem <- elem) {
print(elem + "-")
println()
打印输出如下:
11-12-13-14-15-16-17-18-19-20-
21-22-23-24-25-26-27-28-29-30-
31-32-33-34-35-36-37-38-39-40-
复制代码
六、与Java互操作
由于 Scala 的数组是使用 Java 的数组来实现的,所以两者之间可以相互转换。
import java.util
import scala.collection.mutable.ArrayBuffer
import scala.collection.{JavaConverters, mutable}
object ScalaApp extends App {
val element = ArrayBuffer("hadoop", "spark", "storm")
val javaList: util.List[String] = JavaConverters.bufferAsJavaList(element)
val scalaBuffer: mutable.Buffer[String] = JavaConverters.asScalaBuffer(javaList)
for (elem <- scalaBuffer) {
println(elem)
复制代码
参考资料
Martin Odersky . Scala 编程 (第 3 版)[M] . 电子工业出版社 . 2018-1-1
凯.S.霍斯特曼 . 快学 Scala(第 2 版)[M] . 电子工业出版社 . 2017-7
更多大数据系列文章可以参见 GitHub 开源项目
:
大数据入门指南