scala - 使用 Scala 2.10 进行枚举和映射

标签 scala map mapping enumeration implicit-conversion

我正在尝试将我的应用程序移植到 Scala 2.10.0-M2。我看到了一些不错的改进,编译器发出了更好的警告。但我也遇到了一堆错误,都与我来自 Enumeration.values 的映射有关。 .

我给你举个简单的例子。我想要一个枚举,然后预先创建一堆对象并构建一个使用枚举值作为键然后一些匹配对象作为值的映射。例如:

object Phrase extends Enumeration {
  type Phrase = Value
  val PHRASE1 = Value("My phrase 1")
  val PHRASE2 = Value("My phrase 2")
}

class Entity(text:String)

object Test {
    val myMapWithPhrases = Phrase.values.map(p => (p -> new Entity(p.toString))).toMap  
}

现在这曾经在 Scala 2.8 和 2.9 上工作得很好。但是 2.10.0-M2 给了我以下警告:
[ERROR] common/Test.scala:21: error: diverging implicit expansion for type scala.collection.generic.CanBuildFrom[common.Phrase.ValueSet,(common.Phrase.Value, common.Entity),That]
[INFO] starting with method newCanBuildFrom in object SortedSet
[INFO]   val myMapWithPhrases = Phrase.values.map(p => (p -> new Entity(p.toString))).toMap
                                                 ^

这是什么原因造成的,你如何解决它?

最佳答案

这基本上是一个类型不匹配错误。您可以通过首先将 is 转换为列表来解决它:

scala> Phrase.values.toList.map(p => (p, new Entity(p.toString))).toMap
res15: scala.collection.immutable.Map[Phrase.Value,Entity] = Map(My phrase 1 -> Entity@d0e999, My phrase 2 -> Entity@1987acd)

有关更多信息,请参阅 What's a “diverging implicit expansion” scalac message mean? 的答案和 What is a diverging implicit expansion error?

关于scala - 使用 Scala 2.10 进行枚举和映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9487425/

相关文章:

scala - 如何使用 Scala 和 Mockito 测试异步副作用

map - 有哪些有效的 Geohash 边界框覆盖算法?

java map 删除意外行为

c++ - 如何将对插入 map

java - java/scala 中的原始对象大小和 'as<SomePrimitive>Buffer() 方法调用

scala - Akka Streams - 如何检查流是否成功运行?

java - 在未来的 akka java 中无限期地等待 Actor 的回应

c# - 使用 ValueInjecter 从 ExpandoObject 注入(inject)

java - 如何创建适当的 POJO 来提供 JSON 响应?

c# - 使用 NHibernate 将多列映射到数组