您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實現(xiàn)”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實現(xiàn)”吧!
Tuple拉鏈操作
實際就是將兩個Array合并成一個Tuple,通過Array的zip()方法實現(xiàn),這里需要注意,兩個數(shù)組的長度要一致,不然會丟數(shù)據(jù):
代碼實例:
package com.hadoop.ljs.spark.study
/**
* @author: Created By lujisen
* @company ChinaUnicom Software JiNan
* @date: 2020-02-08 19:59
* @version: v1.0
* @description: com.hadoop.ljs.spark.study
*/
/*Array數(shù)組的zip()方法可將兩個數(shù)組合并成一個tuple*/
object TupleZip {
def main(args: Array[String]): Unit = {
val nameArray=Array("ljs1","ljs2","ljs3")
val nameArray2=Array("ljs1","ljs2","ljs3","ljs4")
val ageArray=Array(17,18,19)
val nameAgeArray=nameArray.zip(ageArray)
println("兩個數(shù)組元素相同")
nameAgeArray.foreach{
x=>println("姓名:"+x._1+" 年齡"+x._2)
}
println("兩個數(shù)組元素不同")
val nameAgeArray2=nameArray2.zip(ageArray)
for((name,age)<-nameAgeArray2){
println("姓名:"+name+" 年齡"+age)
}
/*如果Array元素是一個Tuple,可直接調(diào)用Map(),轉(zhuǎn)換成Map*/
val nameAgeMap=nameAgeArray.toMap
println("轉(zhuǎn)化成Map")
println(nameAgeMap)
}
}
從代碼可看出,當(dāng)兩個Array長度不一致時,只保留了對應(yīng)的數(shù)據(jù),后面多的數(shù)據(jù)直接丟棄了。
由于都運行在JVM上,Java與Scala之間基本能做到無縫的集成,區(qū)別主要在于各自的API各有不同。由于Scala為集合提供了更多便捷的函數(shù),因此,Java與Scala在集合之間的互操作,或許是在這種多語言平臺下使用最為頻繁的。
Scala中操作Java集合
兩種情況需要在Scala中操作Java集合。一種是Scala調(diào)用了其他的Java庫,針對Java集合需要轉(zhuǎn)換為Scala集合,如此才能享受Scala集合提供的福利;另一種是編寫了Scala程序,但需要提供給Java庫,為了更好地?zé)o縫集成,要讓Java庫體會不到Scala的存在。
JavaMap和ScalaMap隱式轉(zhuǎn)換,
代碼實例:
package com.hadoop.ljs.spark.study
import java.util
/**
* @author: Created By lujisen
* @company ChinaUnicom Software JiNan
* @date: 2020-02-08 20:23
* @version: v1.0
* @description: com.hadoop.ljs.spark.study JavaMap和Scala隱式轉(zhuǎn)換
*/
import scala.collection.JavaConversions.mapAsScalaMap
object JavaMapImplicitScalaMap {
def main(args: Array[String]): Unit = {
val javaMap=new util.HashMap[String,Int]()
javaMap.put("ljs1",17)
javaMap.put("ljs2",18)
javaMap.put("ljs3",19)
val scalaMap:scala.collection.mutable.Map[String,Int]=javaMap
println(scalaMap)
import scala.collection.JavaConversions.mapAsJavaMap
val scalaAttrMap = Map("ljs4" -> 20, "ljs5"->22)
val javaMap2 = new util.HashMap[String,Int](scalaAttrMap)
println(javaMap2)
}
}
到此,相信大家對“Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實現(xiàn)”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。