是否有可能(通过宏、某种形式的无形状自动魔法或其他形式)获得密封特征的子类列表:
您不需要任何第三方库来执行此操作:
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)
Output:
对象子类1
对象子类2
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)