是否可以使用class传递泛型参数:
def m(clazz: Class[_]): Unit = {
m2[] //here I want to exact type (that I should have because I have Class)
}
def m2[C: ClassTag]() : List[C] = {
println("hi")
List.empty
}有什么想法吗?
发布于 2021-08-12 12:40:37
当你拥有的只是一个Class时,你想调用一个需要ClassTag的方法。您可以通过Class创建ClassTag,如下所示:
def m(clazz: Class[_]): Unit = {
m2()(ClassTag(clazz))
}发布于 2021-08-14 09:59:18
ClassTag(以及TypeTag和WeakTypeTag)用于将一些编译时信息持久化到运行时。你想以相反的方向做一些事情。您希望在拥有运行时信息(clazz: Class[_])的情况下,在编译时执行某些操作(指定m2的类型参数C )。所以ClassTags无关紧要。
您可以在运行时调用编译器
import scala.tools.reflect.ToolBox
import scala.reflect.runtime.currentMirror
object App {
val tb = currentMirror.mkToolBox()
def m(clazz: Class[_]): Unit = {
tb.eval(tb.parse(s"import App._; m2[${clazz.getName}]"))
}
def m2[C]() : List[C] = {
println("hi")
List.empty
}
def main(args: Array[String]): Unit = {
m(classOf[String]) //hi
}
}libraryDependencies ++= Seq(
scalaOrganization.value % "scala-reflect" % scalaVersion.value,
scalaOrganization.value % "scala-compiler" % scalaVersion.value,
)https://stackoverflow.com/questions/68757112
复制相似问题