我一直在努力寻找一种方法来处理以下情况,我想找到一个统一类型参数的通用视图(或超类),以便我可以访问一个将苹果与苹果进行比较的类型类:
case class Foo[A](i:A) {
def cmp[B:Ordering, C <% B](b:B)(implicit ev: A => B) = implicitly[Ordering[B]].lt(i,b)
}
// Foo(1).cmp(2.0) works
// Foo(1.0).cmp(2) complains about evidence of Double => Int
现在,这可以通过一个简单的函数轻松完成:
def cmp[A:Ordering](a1:A, a2:A) = implicitly[Ordering[A]].lt(a1,a2)
// cmp(Foo(1).a, 1.0)
// cmp(Foo(1.0).a, 1)
但是,我希望它作为 Foo 的一种方法而存在。关于我可以做些什么来强制它使用视图边界的任何想法?