Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實(shí)現(xiàn)

本篇內(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.mapAsScalaMapobject 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)

成都網(wǎng)站建設(shè)公司