如何scala.collection.JavaConversions
取代 Stack Overflow 问题Iterating over Java collections in Scala 中给出的答案(它不起作用,因为“jcl”包已经消失)和Iterate over Map with Scala(它在复杂的测试中对我不起作用稍后我将尝试归结并在此处发布)。
后者实际上是一个 Scala Map 问题,但我认为我需要知道两个答案才能遍历java.util.Map
.
如何scala.collection.JavaConversions
取代 Stack Overflow 问题Iterating over Java collections in Scala 中给出的答案(它不起作用,因为“jcl”包已经消失)和Iterate over Map with Scala(它在复杂的测试中对我不起作用稍后我将尝试归结并在此处发布)。
后者实际上是一个 Scala Map 问题,但我认为我需要知道两个答案才能遍历java.util.Map
.
在 2.8 中,您导入scala.collection.JavaConversions._
并用作 Scala 映射。这是一个示例(在 2.8.0.RC1 中):
scala> val jmap:java.util.Map[String,String] = new java.util.HashMap[String,String]
jmap: java.util.Map[String,String] = {}
scala> jmap.put("Hi","there")
res0: String = null
scala> jmap.put("So","long")
res1: String = null
scala> jmap.put("Never","mind")
res2: String = null
scala> import scala.collection.JavaConversions._
import scala.collection.JavaConversions._
scala> jmap.foreach(kv => println(kv._1 + " -> " + kv._2))
Hi -> there
Never -> mind
So -> long
scala> jmap.keys.map(_.toUpperCase).foreach(println)
HI
NEVER
SO
如果您特别想要一个 Scala 迭代器,请使用jmap.iterator
(在转换导入之后)。