2

我正在尝试使用带有隐式排序的 scala 集合方法来丰富我的库模式。

鉴于此定义:

object ImplicitTest {
  implicit def RichTraversableOnce[A](t: TraversableOnce[A]): RichTraversableOnce[A] =
    new RichTraversableOnce[A](t)

  class RichTraversableOnce[A](val t: TraversableOnce[A]) {
    def myMinBy[B >: A](f: A => B)(implicit cmp: Ordering[B]): A = {
      if (t.isEmpty)
        throw new UnsupportedOperationException("empty.myMinBy")

      t.reduceLeft((x, y) => if (cmp.lteq(f(x), f(y))) x else y)
    }
  }
}

这个测试怎么来的:

 @Test
  def testOrdering {
    import ImplicitTest._
    val mx = List(1, 2, 7, 1, 4, 8, 2, 5, 47, 2, 7).myMinBy(_.toDouble)

    // ...but this works:
    // val mx = List(1, 2, 7, 1, 4, 8, 2, 5, 47, 2, 7).minBy(_.toDouble)

    println(mx)
  }

给我这个编译错误?

错误:没有为 AnyVal {def getClass(): java.lang.Class[_ >: Int with Double <: AnyVal]} 定义隐式排序。val mx = List(1, 2, 7, 1, 4, 8, 2, 5, 47, 2, 7).myMinBy(_.toDouble)

4

1 回答 1

4

B >: A你的in没有理由myMinBy。这就是和AnyVal的最小上限的来源。您的代码适用于IntDoublemyMinBy[B](...)

于 2011-11-23T12:03:23.317 回答