多維數組:數組的元素,還是數組,數組套數組,就是多維數組
- 構造指定行與列的二維數組:Array.ofDim方法
val multiDimArr1 = Array.ofDim[Double](3, 4)
multiDimArr1(0)(0) = 1.0
構建一個指定行與列的二維數組, eg.
package com.sunny.spark.scala.array
/**
* <Description> <br>
*
* @author Sunny<br>
* @taskId: <br>
* @version 1.0<br>
* @createDate 2018/07/14 15:10 <br>
* @see com.yrz.spark.scala.array <br>
*/
object ManyArray1 {
def main(args: Array[String]): Unit = {
//創建一個長度為3的外層數組,數組內的元素是長度為4的數組。也就是三行四列
val manyArray = Array.ofDim[Int](3,4)
manyArray(0)=Array(1,2,3,4)
manyArray(1)=Array(1,2,3,4)
manyArray(2)=Array(1,2,3,4)
/**
* 打印結果為:
* 1234
* 1234
* 1234
*/
for (elem <- manyArray) {
for (elem <- elem) {
print(elem)
}
println()
}
}
}
- 構造不規則多維數組:
val multiDimArr2 = new Array[Array[Int]](3)
multiDimArr2(0) = new Array[Int] (1)
multiDimArr2(1) = new Array[Int] (2)
multiDimArr2(2) = new Array[Int] (3)
multiDimArr2(1)(1) = 1
創建一個不規則的二維數組, eg.
package com.sunny.spark.scala.array
/**
* <Description> <br>
*
* @author Sunny<br>
* @taskId: <br>
* @version 1.0<br>
* @createDate 2018/07/14 15:13 <br>
* @see com.sunny.spark.scala.array <br>
*/
object ManyArray2 {
def main(args: Array[String]): Unit = {
//創建一個長度為3的外層數組,數組里邊的元素是數組
val manyArray = new Array[Array[Int]](3)
manyArray(0) = new Array[Int](1) //第一個元素為長度為1的數組
manyArray(1) = new Array[Int](2) //第二個元素為長度為2的數組
manyArray(2) = new Array[Int](3) //第三個元素為長度為3的數組
manyArray(0)=Array(1)
manyArray(1)=Array(1,2)
manyArray(2)=Array(1,2,3)
/**
* 打印結果為:
* 1
* 12
* 123
*/
for (elem <- manyArray) {
for (elem <- elem) {
print(elem)
}
println()
}
}
}
- Java數據與Scala數組的隱式轉換
Java數組隱式轉換成Scala數組,在需要轉換的函數前邊加上隱式轉換
import scala.collection.JavaConversions.asScalaBuffer
Scala數組轉換成Java數組,在需要轉換的函數前邊加上隱式轉換
import scala.collection.JavaConversions.bufferAsJavaList
Scala代碼中,直接調用JDK(Java)的API,比如調用一個Java類的方法,勢必可能會傳入Java類型的list;Scala中構造出來的list,其實是ArrayBuffer;你直接把Scala的ArrayBuffer傳入Java接收ArrayList的方法,肯定不行。
import scala.collection.JavaConversions.bufferAsJavaList
import scala.collection.mutable.ArrayBuffer
val command = ArrayBuffer("javac", "C:\\Users\\Administrator\\Desktop\\HelloWorld.java")
val processBuilder = new ProcessBuilder(command)
val process = processBuilder.start()
val res = process.waitFor()
import scala.collection.JavaConversions.asScalaBuffer
import scala.collection.mutable.Buffer
val cmd: Buffer[String] = processBuilder.command()