是否有可能(通过宏、某种形式的Shapeless自动化或其他方式)获取密封特质子类的列表:
- 在编译时?
- 在运行时?
是否有可能(通过宏、某种形式的Shapeless自动化或其他方式)获取密封特质子类的列表:
sealed trait MyTrait
case object SubClass1 extends MyTrait
case object SubClass2 extends MyTrait
import scala.reflect.runtime.{universe => ru}
val tpe = ru.typeOf[MyTrait]
val clazz = tpe.typeSymbol.asClass
// if you want to ensure the type is a sealed trait,
// then you can use clazz.isSealed and clazz.isTrait
clazz.knownDirectSubclasses.foreach(println)
输出:
SubClass1 对象
SubClass2 对象
baseAndVariants'
等功能作为答案? - NietzscheanAI