java - 如何通过 java 代码将 java HashMap 转换为不可变的 Scala 映射?

标签 java scala scala-2.10

我需要创建一个 scala.collection.immutable.Map 但我不能使用 Scala 代码,我必须使用 Java。它是怎么做到的?

我不是在寻找空映射,我想将现有的 Java 映射转换为不可变的 Scala 映射。

最佳答案

你可以使用 JavaConverters 来做到这一点

import java.util.HashMap;
import scala.Predef;
import scala.Tuple2;
import scala.collection.JavaConverters;
import scala.collection.immutable.Map;

public class ToScalaTest {
  public static <A, B> Map<A, B> toScalaMap(HashMap<A, B> m) {
    return JavaConverters.mapAsScalaMapConverter(m).asScala().toMap(
      Predef.<Tuple2<A, B>>conforms()
    );
  }

  public static HashMap<String, String> test() {
    HashMap<String, String> m = new HashMap<String, String>();
    m.put("a", "Stackoverflow");
    return m;
  }
}

我们可以证明这在 Scala REPL 中有效

scala> val jm: java.util.HashMap[String, String] = ToScalaTest.test
jm: java.util.HashMap[String,String] = {a=Stackoverflow}

scala> val sm: Map[String, String] = ToScalaTest.toScalaMap(jm)
sm: Map[String,String] = Map(a -> Stackoverflow)

您当然可以从 java 代码中轻松调用此方法

关于java - 如何通过 java 代码将 java HashMap 转换为不可变的 Scala 映射?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36004581/

相关文章:

Scala getter/setter 作为宏

list - 如何从只有索引的 Scala 列表中删除项目?

scala - 带SBT的条件scalacOptions

java - PrintStream是有缓冲的,但是flush不会降低性能,而BufferedOutputStream会加速性能

Java从堆栈跟踪中获取文件的绝对路径

java - java中使用的峰值内存和最大内存有什么区别?

scala - Spark ML VectorAssembler 返回奇怪的输出

java - 抽屉布局在按下后不关闭(取决于 support-v4 lib)

scala - 如何在 Eclipse 中将 Swing 与 Scala 2.11 一起使用?

scala - 我该如何将 "this"封装在Scala宏中?