溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時間:2021-12-08 15:18:33 來源:億速云 閱讀:153 作者:iii 欄目:大數(shù)據(jù)

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

到此,相信大家對“Scala的JavaMap與ScalaMap隱式轉(zhuǎn)換怎么實現(xiàn)”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(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)容。

AI