Scala 如何定义此方法的结果类型?
在以下情况下,如何定义方法返回类型: 工作代码Scala 如何定义此方法的结果类型?,scala,playframework,siena,Scala,Playframework,Siena,在以下情况下,如何定义方法返回类型: 工作代码 def deleteInstance(model: String, uid: Long) = model match { case "menu" => Model.all(classOf[Menu]).filter("uid", uid).get().delete() case "articles" => Model.all(classOf[Articles]).filter("uid", uid).get().del
def deleteInstance(model: String, uid: Long) = model match {
case "menu" => Model.all(classOf[Menu]).filter("uid", uid).get().delete()
case "articles" => Model.all(classOf[Articles]).filter("uid", uid).get().delete()
case "news" => Model.all(classOf[News]).filter("uid", uid).get().delete()
case "image" =>Model.all(classOf[Image]).filter("uid", uid).get().delete()
case "files" =>Model.all(classOf[Files]).filter("uid", uid).get().delete()
case _ => false
}
非工作代码:
class ModelManager{
def getModel(model: String) = {
model match{
case "menu" => classOf[Menu]
case "articles" => classOf[Articles]
case _ => false
}
def deleteInstance(model:String, uid: Long) = {
Model.all(getModel(model)).filter("uid", uid).get().delete()
}
}
}
引发的错误是:
递归方法getModel需要结果
类型
看起来getModel有时会返回一个类,另一些则返回一个布尔类。在Scala中,这通常使用以下类进行建模:
左和右表示两种可能的选择。此方法的调用方需要检查返回值(可能还需要使用模式匹配),以确定该方法返回的是类还是布尔值。似乎您没有在正确的位置使用parens进行关闭。你是说这个吗
class ModelManager{
def getModel(model: String) = {
model match{
// snip
}
} // end method here
def deleteInstance(model:String, uid: Long) = {
Model.all(getModel(model)).filter("uid", uid).get().delete()
}
}
看起来您并不是在试图定义递归方法。。。然后,您可能还需要解决其他问题,因为您需要一个返回Class[u]的方法,而不是Boolean
和Class[u]
(即Any
)的组合。那么这可能会更好吗
def getModel(model: String): Class[_] = {
model match{
case "menu" => classOf[Menu]
case "articles" => classOf[Articles]
} // end method here
看起来您需要一个:
您可以将选项视为最多可以容纳一个元素的容器。保存元素x
的选项是Some(x)
。空选项为None
。选项有几种有用的方法,包括上面使用的map
和getOrElse
方法
map
方法将函数应用于“容器”的每个元素。当然,如果容器是None
,那么它什么也不做(除了更改选项的静态类型)。在您的情况下(假设delete
返回布尔值),map方法会将选项[Class]更改为选项[Boolean]
getOrElse
方法返回选项的元素(如果有),否则返回默认值(false
)
请注意,您还可以使用中定义的condOpt
方法简化实现:
很好,你使用锡耶纳+Scala,这是我想尽快做的一件事。我是锡耶纳的主要开发者,我还打算提供一个锡耶纳4Scala,它将使用Scala的强大功能。。。我真的对你的经验回归感兴趣:D
def getModel(model: String): Class[_] = {
model match{
case "menu" => classOf[Menu]
case "articles" => classOf[Articles]
} // end method here
class ModelManager{
def getModel(model: String) = model match {
case "menu" => Some(classOf[Menu])
case "articles" => Some(classOf[Articles])
case _ => None
}
def deleteInstance(model:String, uid: Long) =
getModel(model) map { m =>
Model.all(m).filter("uid", uid).get().delete()
} getOrElse false
}
class ModelManager{
def getModel(model: String) = condOpt(model) {
case "menu" => classOf[Menu]
case "articles" => classOf[Articles]
}
def deleteInstance(model:String, uid: Long) =
getModel(model) map { m =>
Model.all(m).filter("uid", uid).get().delete()
} getOrElse false
}