1

我正在尝试用 scala 制作一个小型消息传递系统。我不知道如何在线解决这个类/类型/泛型/层次结构问题 //PROBLEM

逻辑是:请求有一个函数列表,当响应到达时调用。当 Response 到达时,调用 getResult 并使用模式匹配。似乎我无法从 Request 列表中调用可以被任何子类型 Response 重载的函数?

object Worksheet {
    class Request {
        //var op = List[( _<:Response ) => Unit]()
        var op = List[Response => Unit]()             // FIXED
    }
    class Response {}
    class MyResult extends Response {}
    class AnotherMyResult extends Response {}

    val map = Map[String, Request]()                  

  def getResult(a:Any) {
    a match {
            ...
        case r:Response =>
            //map.get("").get.op foreach ((o) => o(r)) //PROBLEM 
                      map("").op foreach ((o) => o(r))        //NO PROBLEM 
            ...
    }
  }                                               
}

请帮忙 ;)

编辑

  def simpleop (r:MyResult) : Unit = { }

  def req = new Request()
  req.op += simpleop _                      //PROBLEM STILL

  map += ("" -> req)
4

1 回答 1

0

你不能simpleop用 type 的参数调用方法Response,所以你不能同时拥有:case r:Response => map("").op foreach ((o) => o(r))req.op += simpleop _.

于 2012-12-11T21:42:20.320 回答