如何在一种情况下对每个数字类进行模式匹配?

tkr*_*man 10 scala pattern-matching

假设我有

def foo(x: Any) = x match {
  case s: String => println(0)
  case i: Int => println(1)
  case l: Long => println(2)
  //...
}
Run Code Online (Sandbox Code Playgroud)

有没有办法制作如下的东西?

def foo(x: Any) = x match {
  case s: String => println(0)
  case i: Numeric => println("Numeric")
}
Run Code Online (Sandbox Code Playgroud)

Lee*_*Lee 6

你可以匹配Number界面:

def foo(x: Any) = x match {
  case s: String => println(0)
  case i: java.lang.Number => println("Numeric")
}
Run Code Online (Sandbox Code Playgroud)


Jea*_*let 5

你可以试试这个:

def foo[A](x: A)(implicit num: Numeric[A] = null) = Option(num) match {
  case Some(num) => println("Numeric: " + x.getClass.getName)
  case None => println(0)
}
Run Code Online (Sandbox Code Playgroud)

那么这个

foo(1)
foo(2.0)
foo(BigDecimal(3))
foo('c')
foo("no")
Run Code Online (Sandbox Code Playgroud)

将打印

Numeric: java.lang.Integer
Numeric: java.lang.Double
Numeric: scala.math.BigDecimal
Numeric: java.lang.Character
0
Run Code Online (Sandbox Code Playgroud)

请注意,获得null隐式参数并不意味着不存在这样的隐式参数,而只是在编译时在隐式的搜索范围内没有找到。