在 Scala 中使用 TypeTag 的多态返回类型



我想做的是使用 TypeTag 在 Scala 函数中返回泛型类型。下面是示例代码。

trait Parent[T]
object IntChild extends Parent[Int]
object StringChild extends Parent[String]
object SomeClass {
  def of[A: TypeTag]: Parent[T] = {
    getElementType[A] match {
      case Int => IntChild
      case String => StringChild
    }
  }
}
SomeClass.of[Array[Int]]

但它会引发编译错误。因为返回的of方法类型在编译类型中不是固定的。有没有办法从 TypeTag 获取类型信息并将类型嵌入到返回的类型中?

我期待的是这样的

// T is inferred from TypeTag A.
def of[A: TypeTag, T]: Parent[T] = {
  //...
}

我发现这段代码也没有通过编译。因此,我们需要修复从 A 的 TypeTag 推断的类型信息。

def of[A: TypeTag]: Parent[_] = {
  //...
}

这是错误。

type mismatch;
[error]  found   : Array[Int]
[error]  required: Array[_$1]

如何提前获取元素类型?

我不确定这些定义是否可行。稍微改变一下定义怎么样?

trait Parent[T]
implicit object IntChild extends Parent[Int]
implicit object StringChild extends Parent[String]
object SomeClass {
  def of[A: Parent]: Parent[A] = implicitly
}

这可确保一切都在类型级别完成,以便获得所需的返回类型。它需要 IntChildStringChild 上的 implicit 修饰符。没有必要有另一个名为 T 的类型参数,因为它始终与示例中的A相同。

最新更新