我的应用程序处理许多第三方集成。我有一个用于第三方集成的抽象基类,它指定了集成类应处理的一堆方法–然后可以使用某些功能(并非所有集成都可用)扩展某些集成。
基本上看起来像这样:
abstract class Integration { ... }
trait SingleSignOn { ... }
class NormalIntegration extends Integration {}
class SingleSignOnIntegration extends Integration with SingleSignOn {}
我希望能够整理出具有特定特征的所有集成,这就是我认为的基本解决方案:
val allIntegrations: Seq[Integration] = ...
def integrationsWithTrait[T]: Seq[Integration] = {
allIntegrations.filter(_.isInstanceOf[T])
}
用法是:
val singleSignOnIntegrations = integrationsWithTrait[SingleSignOn]
问题在于isInstanceOf[T]
始终返回true(意味着我以singleSignOnIntegrations == allIntegrations
结尾),而硬编码的isInstanceOf[SingleSignOn]
则按预期工作。
如何固定integrationsWithTrait
使其正常工作?
答案 0 :(得分:6)
这将起作用:
def integrationsWithTrait[T](implicit tag: scala.reflect.ClassTag[T]): Seq[Integration] = {
allIntegrations.filter(tag.runtimeClass.isInstance)
}
Scalac将为调用此方法的每个类注入ClassTag
实例。这将允许在运行时访问Class
对象,并验证该类是否为给定类/特征的实例。
由于类型擦除,我认为原始代码无效。