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
}