Scala: реализация подтипа Numeric [T] - PullRequest
7 голосов
/ 16 февраля 2010

Как можно реализовать подтип Numeric [T]? Я искал руководство по этому вопросу, но не нашел ни одного. Примером подтипов может быть Rational или Complex?

Заранее спасибо Troels

Ответы [ 2 ]

16 голосов
/ 16 февраля 2010

Абсолютно бесполезный String Numeric:

trait StringIsNumeric extends Numeric[String] {
  def plus(x: String, y: String): String = "%s+%s" format (x, y)
  def minus(x: String, y: String): String = "%s-%s" format (x)
  def times(x: String, y: String): String = "%s*%s" format (x, y)
  def quot(x: String, y: String): String = "%s/%s" format (x, y)
  def rem(x: String, y: String): String =  "%s%%s" format (x, y)
  def negate(x: String): String = "-%s" format (x)
  def fromInt(x: Int): String = x.toString
  def toInt(x: String): Int = 0
  def toLong(x: String): Long = 0L
  def toFloat(x: String): Float = 0.0f
  def toDouble(x: String): Double = 0.0
}
implicit object StringIsNumeric extends StringIsNumeric with Ordering.StringOrdering


def x[T: Numeric](t1 : T, t2 : T)  = {
  val n = implicitly[Numeric[T]]
  import n._
  t1 * t2
}
scala> x("a","b")
res0: java.lang.String = a*b
1 голос
/ 16 февраля 2010

Я добавил Реальный в Скалаз, с экземплярами Real[Double] и Real[Dual].

Мне показалось удобным сделать fromDouble неявным

...