是否有可能(通过宏,某种形式的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/

10-12 03:09