本篇內(nèi)容主要講解“Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實(shí)現(xiàn)”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實(shí)現(xiàn)”吧!
堅(jiān)守“ 做人真誠(chéng) · 做事靠譜 · 口碑至上 · 高效敬業(yè) ”的價(jià)值觀,專業(yè)網(wǎng)站建設(shè)服務(wù)10余年為成都成都廣告制作小微創(chuàng)業(yè)公司專業(yè)提供成都企業(yè)網(wǎng)站定制營(yíng)銷網(wǎng)站建設(shè)商城網(wǎng)站建設(shè)手機(jī)網(wǎng)站建設(shè)小程序網(wǎng)站建設(shè)網(wǎng)站改版,從內(nèi)容策劃、視覺(jué)設(shè)計(jì)、底層架構(gòu)、網(wǎng)頁(yè)布局、功能開(kāi)發(fā)迭代于一體的高端網(wǎng)站建設(shè)服務(wù)。
Tuple拉鏈操作
實(shí)際就是將兩個(gè)Array合并成一個(gè)Tuple,通過(guò)Array的zip()方法實(shí)現(xiàn),這里需要注意,兩個(gè)數(shù)組的長(zhǎng)度要一致,不然會(huì)丟數(shù)據(jù):
代碼實(shí)例:
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()方法可將兩個(gè)數(shù)組合并成一個(gè)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("兩個(gè)數(shù)組元素相同")
nameAgeArray.foreach{
x=>println("姓名:"+x._1+" 年齡"+x._2)
}
println("兩個(gè)數(shù)組元素不同")
val nameAgeArray2=nameArray2.zip(ageArray)
for((name,age)<-nameAgeArray2){
println("姓名:"+name+" 年齡"+age)
}
/*如果Array元素是一個(gè)Tuple,可直接調(diào)用Map(),轉(zhuǎn)換成Map*/
val nameAgeMap=nameAgeArray.toMap
println("轉(zhuǎn)化成Map")
println(nameAgeMap)
}
}
從代碼可看出,當(dāng)兩個(gè)Array長(zhǎng)度不一致時(shí),只保留了對(duì)應(yīng)的數(shù)據(jù),后面多的數(shù)據(jù)直接丟棄了。
由于都運(yùn)行在JVM上,Java與Scala之間基本能做到無(wú)縫的集成,區(qū)別主要在于各自的API各有不同。由于Scala為集合提供了更多便捷的函數(shù),因此,Java與Scala在集合之間的互操作,或許是在這種多語(yǔ)言平臺(tái)下使用最為頻繁的。
Scala中操作Java集合
兩種情況需要在Scala中操作Java集合。一種是Scala調(diào)用了其他的Java庫(kù),針對(duì)Java集合需要轉(zhuǎn)換為Scala集合,如此才能享受Scala集合提供的福利;另一種是編寫了Scala程序,但需要提供給Java庫(kù),為了更好地?zé)o縫集成,要讓Java庫(kù)體會(huì)不到Scala的存在。
JavaMap和ScalaMap隱式轉(zhuǎn)換,
代碼實(shí)例:
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)
}
}
到此,相信大家對(duì)“Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實(shí)現(xiàn)”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
分享標(biāo)題:Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實(shí)現(xiàn)
網(wǎng)站URL:http://muchs.cn/article42/jpidhc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、Google、App設(shè)計(jì)、營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站營(yíng)銷、響應(yīng)式網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)