Размышления о типе членов?
Я знаю, что это возможно:
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 ответ
Решение
Scala позволяет ссылаться на аргументы слева от функции с карри (в данном случае foo
):
def isDouble(foo: Foo)(implicit ev: ClassTag[foo.A]) = classTag[foo.A].runtimeClass == classOf[Double]