Scala多維數組、Java數組與Scala數組的隱式轉換

多維數組:數組的元素,還是數組,數組套數組,就是多維數組

  • 構造指定行與列的二維數組: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()
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 借著90后這十八歲的梗,讓我們這一群中年少年、少女們熱鬧了一把,追憶了一下自己的二八年華。 借著照片,也把我們好像...
    隨緣_2f1a閱讀 486評論 0 0
  • ? 高原的烈日,成就了兩朵璀璨紅霞 任憑沙撫風吹,不懼雨淋雪侵 逆境下 卻越發豐盛飽滿 左右映襯,相得益彰 你執我...
    e86faa97ed6d閱讀 225評論 0 0
  • 雖然這是tk的教程,但是我個人還是比較推薦使用pyqt來寫窗口,實際上pyqt配合qtdesigner寫的窗口不僅...
    遺步看風景閱讀 40,187評論 3 39
  • 最近看的pdf 非常多,但沒有啥現成的軟件解決了 最近閱讀的問題,用了N年的老mac,找文件/organizati...
    那不勒斯抹茶羽衣南瓜餅閱讀 959評論 0 0