如何让我的重载构造函数接受任何数字类型?

时间:2017-08-25 22:09:05

标签: scala types constructor-overloading

我有一个CoordVector课程,接受Vector[ComplexNumber],其中ComplexNumber是我在其他地方定义的课程,我也会覆盖它以接受Vector[Double]。但我希望覆盖在Scala中接受任何数字类型。

这是我目前的代码

case class RealVector(vector: Vector[Double])
case class ComplexVector(vector: Vector[ComplexNumber])

import scala.language.implicitConversions
implicit def dv(vector: Vector[Double]) = RealVector(vector)
implicit def cv(vector: Vector[ComplexNumber]) = ComplexVector(vector)

object CoordVector {
    def apply(components:RealVector):CoordVector = {
        new CoordVector(components.vector.map(c => ComplexNumber(c, 0)))
    }
}

case class CoordVector(val components:ComplexVector) {
    ...
}

很遗憾,我无法用Double替换Numeric,但有一种简单的方法可以做到这一点而无需创建新的implicit defapply对于每种数字类型?

1 个答案:

答案 0 :(得分:1)

看看你是否得到了你想要的东西。

class ComplexNumber(a:Double, b:Double) // put here just to make the rest compile

case class RealVector[N:Numeric](vector: Vector[N])
case class ComplexVector(vector: Vector[ComplexNumber])

import scala.language.implicitConversions
implicit def dv[N:Numeric](vector: Vector[N]) = RealVector(vector)
implicit def cv(vector: Vector[ComplexNumber]) = ComplexVector(vector)

object CoordVector {
  def apply[N:Numeric](components:RealVector[N]):CoordVector = {
    new CoordVector(components.vector.map(c =>
      new ComplexNumber(implicitly[Numeric[N]].toDouble(c), 0)))
  }
}

case class CoordVector(components:ComplexVector) {
  ???
}

这允许所有基础数​​字数据为Double,但您可以使用类型为RealVectorVector[Int]或{{1}的构造函数参数创建Vector[Long]个实例等等。