定长数组
1、如果你需要一个长度不变的数组可以用,Scala中的Array。
举个栗子:
scala> val nums = new Array[Int](10)
nums: Array[Int] = Array(0, 0, 0, 0, 0, 0, 0, 0, 0, 0)//10个整数的数组,所有元素被初始化为0
scala> val a = new Array[String](10)
a: Array[String] = Array(null, null, null, null, null, null, null, null, null, null)//10个元素的字符串数组,所有元素初始化为null
scala> val s = Array("Hello","world")
s: Array[String] = Array(Hello, world)
//长度为2的Array[String]——类型是推断出来的
//说明:已提供初始值就不需要new
scala> s(0) = "GoodBye"
scala> s
res1: Array[String] = Array(GoodBye, world)
//使用()而不是[] 来访问元素
2、在JVM中,Scala的Array以java数组方式实现。上面例子中的数组在JVM中的类型为java.lang.String[]
Int、Double或其他与java中基本类型对应的数组都是基本类型数组。
变长数组:数组缓冲
1、对于那种程度需要变化的数组,java有ArrayList,C++有vector。Scala中的等效数据结构为ArrayBuffer。
举个栗子:
2、在数组缓冲的尾端添加或移除元素是一个高效的操作。你也可以在任意位置插入或移除元素,但这样的操作并不是那么高效——所有那个位置以后的元素都必须被平移。
举个栗子:
3、有时候你需要构建一个Array,但不知道最终需要装多少元素。在这种情况下,先构建一个数组缓冲,然后调用
反过来,调用a.toBuffer可以将一个数组a转换成数组缓冲。
遍历数组和数组缓冲
1、在Java和C++中,数组和数组列表/向量有一些语法上不同。Scala则更加统一。大多时候,你可以用相同的代码处理这两种数据结构。
以下是for循环遍历数组或数组缓冲的例子:
until是RichInt类的方法,返回所有小于(但不包括)上限的数字,举个栗子: