Scala 数组

Scala 语言中提供的数组是用来存储固定大小的同类型元素,数组对于每一门编辑应语言来说都是重要的数据结构之一。

声明数组变量并不是声明 number0、number1、…、number99 一个个单独的变量,而是声明一个就像 numbers 这样的变量,然后使用 numbers[0]、numbers[1]、…、numbers[99] 来表示一个个单独的变量。数组中某个指定的元素是通过索引来访问的。

数组的第一个元素索引为0,最后一个元素的索引为元素总数减1。

声明数组

以下是 Scala 数组声明的语法格式:

  1. var z:Array[String] = new Array[String](3)
  2. var z = new Array[String](3)

以上语法中,z 声明一个字符串类型的数组,数组长度为 3 ,可存储 3 个元素。我们可以为每个元素设置值,并通过索引来访问每个元素,如下所示:

  1. z(0) = "Taobao"; z(1) = "Baidu"; z(4/2) = "Google"

最后一个元素的索引使用了表达式 4/2 作为索引,类似于 z(2) = "Google"

我们也可以使用以下方式来定义一个数组:

  1. var z = Array("Taobao", "Baidu", "Google")

下图展示了一个长度为 10 的数组 myList,索引值为 0 到 9:

Scala 数组 - 图1

处理数组

数组的元素类型和数组的大小都是确定的,所以当处理数组元素时候,我们通常使用基本的 for 循环。

以下实例演示了数组的创建,初始化等处理过程:

  1. object Test {
  2. def main(args: Array[String]) {
  3. var myList = Array(1.9, 2.9, 3.4, 3.5)
  4. // 输出所有数组元素
  5. for ( x <- myList ) {
  6. println( x )
  7. }
  8. // 计算数组所有元素的总和
  9. var total = 0.0;
  10. for ( i <- 0 to (myList.length - 1)) {
  11. total += myList(i);
  12. }
  13. println("总和为 " + total);
  14. // 查找数组中的最大元素
  15. var max = myList(0);
  16. for ( i <- 1 to (myList.length - 1) ) {
  17. if (myList(i) > max) max = myList(i);
  18. }
  19. println("最大值为 " + max);
  20. }
  21. }

执行以上代码,输出结果为:

  1. $ scalac Test.scala
  2. $ scala Test
  3. 1.9
  4. 2.9
  5. 3.4
  6. 3.5
  7. 总和为 11.7
  8. 最大值为 3.5

多维数组

多维数组一个数组中的值可以是另一个数组,另一个数组的值也可以是一个数组。矩阵与表格是我们常见的二维数组。

以上是一个定义了二维数组的实例:

  1. var myMatrix = ofDim[Int](3,3)

实例中数组中包含三个数组元素,每个数组元素又含有三个值。

接下来我们来看一个二维数组处理的完整实例:

  1. import Array._
  2. object Test {
  3. def main(args: Array[String]) {
  4. var myMatrix = ofDim[Int](3,3)
  5. // 创建矩阵
  6. for (i <- 0 to 2) {
  7. for ( j <- 0 to 2) {
  8. myMatrix(i)(j) = j;
  9. }
  10. }
  11. // 打印二维阵列
  12. for (i <- 0 to 2) {
  13. for ( j <- 0 to 2) {
  14. print(" " + myMatrix(i)(j));
  15. }
  16. println();
  17. }
  18. }
  19. }

执行以上代码,输出结果为:

  1. $ scalac Test.scala
  2. $ scala Test
  3. 0 1 2
  4. 0 1 2
  5. 0 1 2

合并数组

以下实例中,我们使用 concat() 方法来合并两个数组,concat() 方法中接受多个数组参数:

  1. import Array._
  2. object Test {
  3. def main(args: Array[String]) {
  4. var myList1 = Array(1.9, 2.9, 3.4, 3.5)
  5. var myList2 = Array(8.9, 7.9, 0.4, 1.5)
  6. var myList3 = concat( myList1, myList2)
  7. // 输出所有数组元素
  8. for ( x <- myList3 ) {
  9. println( x )
  10. }
  11. }
  12. }

执行以上代码,输出结果为:

  1. $ scalac Test.scala
  2. $ scala Test
  3. 1.9
  4. 2.9
  5. 3.4
  6. 3.5
  7. 8.9
  8. 7.9
  9. 0.4
  10. 1.5

创建区间数组

以下实例中,我们使用了 range() 方法来生成一个区间范围内的数组。range() 方法最后一个参数为步长,默认为 1:

  1. import Array._
  2. object Test {
  3. def main(args: Array[String]) {
  4. var myList1 = range(10, 20, 2)
  5. var myList2 = range(10,20)
  6. // 输出所有数组元素
  7. for ( x <- myList1 ) {
  8. print( " " + x )
  9. }
  10. println()
  11. for ( x <- myList2 ) {
  12. print( " " + x )
  13. }
  14. }
  15. }

执行以上代码,输出结果为:

  1. $ scalac Test.scala
  2. $ scala Test
  3. 10 12 14 16 18
  4. 10 11 12 13 14 15 16 17 18 19

Scala 数组方法

下表中为 Scala 语言中处理数组的重要方法,使用它前我们需要使用 import Array._ 引入包。

序号方法和描述
1 def apply( x: T, xs: T* ): Array[T] 创建指定对象 T 的数组, T 的值可以是 Unit, Double, Float, Long, Int, Char, Short, Byte, Boolean。
2 def concatT: Array[T] 合并数组
3 def copy( src: AnyRef, srcPos: Int, dest: AnyRef, destPos: Int, length: Int ): Unit 复制一个数组到另一个数组上。相等于 Java's System.arraycopy(src, srcPos, dest, destPos, length)。
4 def empty[T]: Array[T] 返回长度为 0 的数组
5 def iterateT( f: (T) => T ): Array[T] 返回指定长度数组,每个数组元素为指定函数的返回值。 以上实例数组初始值为 0,长度为 3,计算函数为a=>a+1
  1. scala> Array.iterate(0,3)(a=>a+1)
  2. res1: Array[Int] = Array(0, 1, 2)
6 def fillT(elem: => T): Array[T] 返回数组,长度为第一个参数指定,同时每个元素使用第二个参数进行填充。
7 def fillT( elem: => T ): Array[Array[T]] 返回二数组,长度为第一个参数指定,同时每个元素使用第二个参数进行填充。
8 def ofDimT: Array[T] 创建指定长度的数组
9 def ofDimT: Array[Array[T]] 创建二维数组
10 def ofDimT: Array[Array[Array[T]]] 创建三维数组
11 def range( start: Int, end: Int, step: Int ): Array[Int] 创建指定区间内的数组,step 为每个元素间的步长
12 def range( start: Int, end: Int ): Array[Int] 创建指定区间内的数组
13 def tabulateT(f: (Int)=> T): Array[T] 返回指定长度数组,每个数组元素为指定函数的返回值,默认从 0 开始。 以上实例返回 3 个元素:
  1. scala> Array.tabulate(3)(a => a + 5)
  2. res0: Array[Int] = Array(5, 6, 7)
14 def tabulateT( f: (Int, Int ) => T): Array[Array[T]] 返回指定长度的二维数组,每个数组元素为指定函数的返回值,默认从 0 开始。