对类型成员的反思?

时间:2016-01-29 22:22:08

标签: scala scala-reflect scala-generics

我知道这是可能的:

import scala.reflect._

trait Foo[A]

def isDouble[A: ClassTag](foo: Foo[A]) = classTag[A].runtimeClass == classOf[Double]

object Foo1 extends Foo[Double]
object Foo2 extends Foo[String]
assert(isDouble(Foo1))
assert(!isDouble(Foo2))

但是,现在我想让A成为抽象类型:

import scala.reflect._

trait Foo {
  type A
}

def isDouble(foo: Foo): Boolean = ???

object Foo1 extends Foo {override type A = Double}
object Foo2 extends Foo {override type A = String}
assert(isDouble(Foo1))
assert(!isDouble(Foo2))

如何实施isDouble功能?

1 个答案:

答案 0 :(得分:0)

Scala让您将参数引用到curried函数的左侧(在本例中为foo):

def isDouble(foo: Foo)(implicit ev: ClassTag[foo.A]) = classTag[foo.A].runtimeClass == classOf[Double]