我有一个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 def
和apply
对于每种数字类型?
答案 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
,但您可以使用类型为RealVector
或Vector[Int]
或{{1}的构造函数参数创建Vector[Long]
个实例等等。