1.Array
-
Scala中,Array代表的含义与Java中类似,表示的是长度不可变的数组。由于Scala与Java都是运行在JVM中,双方可以互相调用,因此,Scala数组的底层实际上是Java数组。如字符串数组在底层就是Java的String[],整数数组在底层就是Java的Int[]。
-
数组初始化后,数组长度就固定下来了,而且数组元素全部根据其类型初始化
val a = new Array[Int](10) val b = new Array[String](10)
-
可以直接使用Array()创建数组,其元素类型将自动推断
val a = Array("hello", "world") a(0) = "hi" val b = Array("hello", 10)
2.ArrayBuffer
-
在scala中,如果需要类似于Java中的ArrayList这种长度可变的集合类,则可以使用ArrayBuffer
-
如果不想每次都是用全限定名,则可以预先导入ArrayBuffer
import scala.collection.mutable.ArrayBuffer
-
使用ArrayBuffer()的方式可以创建一个空的ArrayBuffer
val a = ArrayBuffer[Int]()
-
+=操作符:可以向ArayBuffer中添加一个或多个元素,这种语法必须牢记,在Spark源码中大量使用了这种集合操作语法
-
++=操作符:可以向ArrayBuffer中添加其他集合中的所有元素
-
trimEnd()函数 :可以从尾部截断指定个数的元素
-
insert()函数 :该函数可以在指定位置插入元素(位置是从下标0开始的),这种操作效率很低,因为需要移动指定位置后的所有元素。如a.insert(5, 6),表示的是在下标为5的地方添加值为6的元素,也可以同时添加多个元素,如a.insert(6,7,8,9,10),在下标6的地方添加7、8、9、10四个元素。下图例子中需定义a数组,val a = Array(1,2,3,4,5)
-
remove()函数:移除指定位置的元素,如a.remove(1),表示移除下标为1的元素即a数组中值为2的元素;可以同时移除多个元素,如a.remove(1,3) ,表示从下标为1的地方开始,移除3个元素
-
Array与ArrayBuffer可以互相转换:toArray/toBuffer
-
现有一个Array数组,需要向其中添加元素,就可以使用toBuffer方法,把Array转换成ArrayBuffer,然后添加元素并使用toArray方法,转换成Array
3.遍历Array和ArrayBuffer
-
使用for循环和util遍历Array/ArrayBuffer
for(i <- 0 until a.length) println(a(i))
-
跳跃遍历Array/ArrayBuffer
for(i <- 0 until (a.length, 2)) println(a(i))
-
从尾部遍历
for(i <- (0 until a.length).reverse) println(a(i))
-
增强for循环遍历
4.数组常见操作
-
数组元素求和
-
获取数组最大值
-
对数组排序
scala.util.Sorting.quickSort(a2)
-
获取数组中所有元素内容,mkString
-
toString函数