当我注意到这种古怪的行为时,我今天写了一些代码。嵌套在可变映射中的不可变映射似乎允许(通常是可变的)+ =运算符。
scala> val myMutableMap = mutable.Map[String, scala.collection.immutable.Map[String, String]]()
myMutableMap: scala.collection.mutable.Map[String,scala.collection.immutable.Map[String,String]] = Map()
scala> myMutableMap += "outerkey" -> scala.collection.immutable.Map("k1"-> "v1")
res25: myMutableMap.type = Map(outerkey -> Map(k1 -> v1))
scala> myMutableMap("outerkey") += "k2"->"v2"
scala> myMutableMap
res27: scala.collection.mutable.Map[String,scala.collection.immutable.Map[String,String]] = Map(outerkey -> Map(k1 -> v1, k2 -> v2))
scala> val huhwhat = myMutableMap("outerkey")
huhwhat: scala.collection.immutable.Map[String,String] = Map(k1 -> v1, k2 -> v2)
scala> huhwhat += "k3"->"k4"
<console>:21: error: value += is not a member of scala.collection.immutable.Map[String,String]
huhwhat += "k3"->"k4"
我查看了Map.scala源代码,但没有看到任何可以继承+ =运算符的明显答案。
这是在Scala 2.11.5上。有谁知道发生了什么?
答案 0 :(得分:3)
myMutableMap("outerkey") += "k2"->"v2"
被编译器解释为
myMutableMap("outerkey") = myMutableMap("outerkey") + ("k2"->"v2")
即,使用添加的密钥myMutableMap("outerkey")
从不可变("k2"->"v2")
创建新地图,并使用新对myMutableMap
更新("outerkey" -> <the new map>)
。
这是由mutable.MapLike
update
method实施的,this blog post提供foo(x) = y
行为。有关详细信息,请参阅a bunch of other magic functions in Scala(还有一个SO答案列表{{3}})。