4

在实现带有模式匹配的 def 时如何避免包装 args ?

例子 :

def myDef(a: A, b:B, c: C): D = (a,c,d) match {
  case ('qsdqsd, _ , _ ) => ???
  case _ => ???
}
4

2 回答 2

9

您可以将元组作为函数参数:

def myDef(abc: (A,B,C)): D = abc match {
  case ('qxpf, _, _) => ???
  case _ => ???
}

用户将自动将他们的非元组参数列表提升为元组。观察:

scala> def q(ab: (Int,String)) = ab.swap
q: (ab: (Int, String))(String, Int)

scala> q(5,"Fish")
res1: (String, Int) = (Fish,5)
于 2012-09-26T18:05:05.320 回答
4

您可以将其声明为 aPartialFunction以便您可以case直接使用 -block。这是因为cases块Scala 中的 PartialFunction。

val myDef: PartialFunction[(A, B, C), D] = {
  case ("qsdqsd", b, c) => b + c
  case _ => "no match"
}

println(myDef("qsdqsd", "b", "c"))
println(myDef("a", "b", "c"))
于 2012-09-26T18:04:31.547 回答