Scala类型不匹配同一父节点的子类

时间:2016-03-14 16:41:32

标签: scala apache-spark spray

UserGetResponse和GeneralResponse是BaseResponse的子类,如下所示:

abstract class BaseResponse()

我用来检索用户的函数如下:

  def userGet(userId: Int)(implicit ec: ExecutionContext): Future[BaseResponse] = Future {
    val response = users.get(userId) map { user =>
        val userRes = new UserResponse(user.id, user.firstname, user.lastname, user.organisationid, user.email, user.password, user.usertype)
        new UserGetResponse(1, "Successful retrieved the user.", userRes)
    } getOrElse {
      GeneralResponse(0, s"Error retrieving user. User does not exist.")
    }
  }

其中users是另一个定义了get,insert等方法的类。我收到以下编译错误:

 type mismatch;
[error]  found   : Unit
[error]  required: package.name.BaseResponse
[error]   }

我做错了什么?

1 个答案:

答案 0 :(得分:5)

Future内的闭包没有返回任何内容,因此编译器推断它的返回类型为Unit,并且抱怨因为它应该是BaseResponse

从函数开头删除val response =(或在结束前添加response)应修复它。