Java与Scala互相调用时容器的转换(List、Map为例)

最近新入职公司,所在项目组使用hadoop较多,基本都在使用spark做计算,为了更好的操作spark最近也在学习scala这门语言(原因:spark源码是scala)。

新遇问题:众所周知,java 和scala是可以相互调用的,在调用的时候,集合类的相互转化会有问题。也就是说,java的List和scala的List是不一样的,解决后以此记录。

以下为官方可直接转换列表(单向 =>, 双向<=>):

scala.collection.Iterable <=> .java.lang.Iterable

scala.collection.Iterable <=> java.util.Collection

scala.collection.Iterator <=> java.util.{ Iterator, Enumeration }

scala.collection.mutable.Buffer <=> java.util.List

scala.collection.mutable.Set <=> java.util.Set

scala.collection.mutable.Map <=> java.util.{ Map, Dictionary }

scala.collection.mutable.ConcurrentMap <=> java.util.concurrent.ConcurrentMap

scala.collection.Seq         => java.util.List

scala.collection.mutable.Seq => java.util.List

scala.collection.Set         => java.util.Set

scala.collection.Map         => java.util.Map

java.util.Properties         => scala.collection.mutable.Map[String, String]

转换的关键在于:   scala.collection.JavaConverters   这个工具类包含了基本的转换情景

话不多说上代码:

· Scala代码:

/**
 * Map 互相转换
 **/
def convert2JavaMap(scalaMap: Map[String, String]): Unit = {
  //scala Map ==> java Map
  val javaMap: util.Map[String, String] = scalaMap.asJava
  //java Map ==> scala Map
  import scala.collection.JavaConversions.mapAsScalaMap
  val scalaMap1: scala.collection.mutable.Map[String, String] = javaMap
}

/**
  * List 互相转换
  **/
def convert2JavaList(scalaList: List[String]): Unit = {
  //java List ==> scala List
  val javaList: java.util.List[String] = scalaList.asJava
  //scala List ==> java List
  val buffer: scala.collection.mutable.Buffer[String] = javaList.asScala
  val list: List[String] = buffer.toList
}
/** 
  * 略微复杂的结构
  **/
def convert2JavaMaps(scalaMapList: List[Map[String, String]]): java.util.List[java.util.Map[String, String]] = {
  val arrayBuffer = ArrayBuffer[util.Map[String, String]]()
  val javaList: util.List[Map[String, String]] = scalaMapList.asJava
  for (i <- 0 until javaList.size()) {
    val javaMap: util.Map[String, String] = javaList.get(i).asJava
    arrayBuffer += javaMap
  }
  val javaMapList: util.List[util.Map[String, String]] = arrayBuffer.toArray.toList.asJava
  javaMapList
}

· Java代码:

/**
 * List 互相转换
 **/
public static void convert2List(scala.collection.immutable.List<String> scalaList){
    //scala List ==> java List
    List<String> javaList = JavaConversions.seqAsJavaList(scalaList);
    //java List ==> scala List
    scalaList = JavaConversions.asScalaIterator(javaList.iterator()).toSeq().toList();
}
/**
  * Map 互相转换
 **/
public static void convert2Map(scala.collection.Map<String, String> scalaMap){
    //scala Map ==> java Map
    Map<String, String> javaMap = JavaConversions.mapAsJavaMap(scalaMap);
    //java List ==> scala List
    scalaMap= JavaConversions.mapAsScalaMap(javaMap);
}

如何选择这几种方法,取决于在哪边抽象成工具,统一处理。

初学者总结,如有不当请指教。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值