泛型类型类实例性能



假设我有一个类型类

trait CanMeow[T] {
    def meow(t:T):String
}

现在我有一个不同类型的

trait IsCatEquivalent[T] {
    def makeSound(t:T):String
    def isAlive(t:T):Boolean
}

现在,我想使CanMeow类型类的每个CatEquivalent成员。我能做的是

implicit def catEquivalentCanMeow[T](implicit ce:IsCatEquivalent[T]) = new CanMeow[T] {
    def meow(t:T) = ce.makeSound(t)
}

这对性能有何影响?从外观上看,每次使用CanMeow[T]类型的隐式参数调用方法时,都会构造一个新对象。是这样吗?如果,这是否足够便宜,以至于不值得缓存实例?

另一个问题是:有更好的方法吗?(让一个类型类扩展另一个可能不是一个选项,例如,如果它们来自不同的库)

要比较隐式转换及其替代方案对性能的影响,请参阅本文。这个问题包含另一个微观基准。

最新更新