Dmi*_*tov 1 scala implicit scala-reflect
我有一个带有函数的简单代码,它获取weakTypeOf case 类并返回其字段,可以预见我们得到2 个项目列表
def getMembers[T: WeakTypeTag] =
weakTypeOf[T].members.filterNot(_.isMethod).toList
final case class Person(name: String, age: Int) extends Models
val fields = getMembers[Person]
println(fields.length) // 2
Run Code Online (Sandbox Code Playgroud)
它工作正常
但是,如果我想在创建子对象类时从将 Person 作为类型参数传递的 trait 中获取成员呢?(WeakTypeTag 在构建过程中无法传递给 trait)
trait ModelManager[CCT] {
def getMembers: List[String] = ???
}
case object PersonManager extends ModelManager[Person]
val fields = PersonManager.getMembers
println(fields.length)
Run Code Online (Sandbox Code Playgroud)
有没有办法从 CCT 参数中获取 weakTypeOf ?
尝试向方法添加隐式参数
trait ModelManager[CCT] {
def getMembers(implicit weakTypeTag: WeakTypeTag[CCT]): List[Symbol] =
weakTypeTag.tpe.members.filterNot(_.isMethod).toList
}
Run Code Online (Sandbox Code Playgroud)
或使特征成为抽象类
abstract class ModelManager[CCT: WeakTypeTag] {
def getMembers: List[Symbol] = weakTypeOf[CCT].members.filterNot(_.isMethod).toList
}
Run Code Online (Sandbox Code Playgroud)