2

我创建了一个 ObservableMap,以及一个只打印它接收到的任何事件的订阅者(取自此处):

class MyMap extends HashMap[Int,Int] with ObservableMap[Int,Int]

class MySub extends Subscriber[Message[(Int,Int)] with Undoable, ObservableMap[Int, Int]] {
  def notify(pub: ObservableMap[Int, Int], evt: Message[(Int, Int)] with Undoable) { 
    println(evt)
  }
}

val map = new MyMap
map.subscribe(new MySub)

使用+=++=-=按预期工作:

scala> map += 1 -> 1
Include(NoLo,(1,1))
res5: map.type = Map(1 -> 1)

scala> map ++= Map(2 -> 4, 3 -> 9)
Include(NoLo,(3,9))
Include(NoLo,(2,4))
res6: map.type = Map(3 -> 9, 1 -> 1, 2 -> 4)

scala> map -= 1
Remove(NoLo,(1,1))
res7: map.type = Map(3 -> 9, 2 -> 4)

更新不起作用:

scala> map(4) = 16

scala> map
res9: MyMap = Map(3 -> 9, 4 -> 16, 2 -> 4)

为什么?看起来 ObservableMap 覆盖了+=-=clear++=update似乎都是根据 += 实现的(分别由 Growable 和 MapLike 实现),那么为什么它适用于一个而不适用于另一个呢?

4

1 回答 1

3

HashMap 的可变版本调用 update ,而 update 又调用 put ,它不调用 += 所以 observable += 方法不会被调用。我正在使用 scala 2.9.1,但这应该与 2.8 相同。

从哈希映射:

  override def put(key: A, value: B): Option[B] = {
    val e = findEntry(key)
    if (e == null) { addEntry(new Entry(key, value)); None }
    else { val v = e.value; e.value = value; Some(v) }
  }

  override def update(key: A, value: B): Unit = put(key, value)

  def += (kv: (A, B)): this.type = { 
    val e = findEntry(kv._1)
    if (e == null) addEntry(new Entry(kv._1, kv._2))
    else e.value = kv._2
    this
  }
于 2012-05-31T21:26:56.350 回答