是否有可能(通过宏,某种形式的Shapeless automagic或其他方式)获得密封特征的子类列表:
在编译时?
在运行时?
最佳答案
您不需要任何第三方库即可执行此操作:
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
关于scala - 获取密封特征的子类,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34534002/