我有一个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
为每个数字类型?
看看这是否符合您的要求。
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]
、 or Vector[Long]
、 orVector[Float]
等的构造函数参数创建实例。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句