来自类型参数的 WeakTypeOf

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 ?

Dmy*_*tin 5

尝试向方法添加隐式参数

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)