[英]How to find super class from MemberScope reflection
我正在使用几种反射方法:
def typeMirror = runtimeMirror(this.getClass.getClassLoader)
def instanceMirror = typeMirror.reflect(this)
def members = instanceMirror.symbol.typeSignature.members
从成员,我正在尝试做这样的事情(我知道这是不正确的,但是我已经尝试了各种方法而没有成功):
def modelMembers = members.filter(member => member.typeSignature == Model)
其中Model是超类。 问题是我似乎只能弄清楚子类typeSignature。 如何根据成员是Model的子类来过滤成员?
有一个非常方便的<:<
运算符来测试一个类型是否是另一个的子类型:
def modelMembers = members.filter(_.typeSignature <:< typeOf[Model])
注意 :这只会为您提供字段,而不是具有Model
返回类型的方法。
例:
trait A
class B extends A
class C extends A
class X {
val hello: C = null
var world: B = null
}
scala> import reflect.runtime.universe._
import reflect.runtime.universe._
scala> typeOf[X].members.filter(_.typeSignature <:< typeOf[A])
res0: Iterable[Symbol] = SynchronizedOps(variable world, value hello)
它似乎对我有用吗?
package load.data
abstract class AbstractPoint
case class Point() extends AbstractPoint
object ModelTest {
def main(arg: Array[String]) =
{
val li = List(new Point())
assert(li.filter(_.isInstanceOf[AbstractPoint]).length == 1)
}
}
发现了一点骇客。 如果有人知道更具体的方式,我很乐意看到。
def modelMembers = {
val filtered = members.filter(member => member.typeSignature.baseClasses.size > 0 && member.isTerm && !member.isMethod)
filtered.filter(_.typeSignature.baseClasses.exists(_.name.toString == "Model"))
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.