查看绑定方法,有序特征和隐式转换

use*_*364 3 sorting scala

如果我有一个具有以下签名的方法:

def max[T <% Ordered[T]](list:List[T]): T={ 
 //return max. element of List (for example)
}
Run Code Online (Sandbox Code Playgroud)

我想给它一个这样的对列表:

val fu:List[Pair[String, Double]] = List(Pair("a", 3.1),Pair("b", 1.7),Pair("c", 3.1),Pair("d", 5.4))
Run Code Online (Sandbox Code Playgroud)

如何在列表的第二个元素上定义排序,以便我能够在函数中使用它?

我试着用

implicit def wrapper(p: Pair[String, Double])=new runtime.RichDouble(p._2)
Run Code Online (Sandbox Code Playgroud)

隐式地将对的Double转换为扩展有序特征的RichDouble,但这不起作用.

4e6*_*4e6 6

给定:

scala> def max[T <% Ordered[T]](xs: List[T]) = xs.max
max: [T](xs: List[T])(implicit evidence$1: T => Ordered[T])T

scala> case class Pair(x: String, y: Double)
defined class Pair
Run Code Online (Sandbox Code Playgroud)

您需要为以下内容定义排序对象Pair:

scala> implicit val order = scala.math.Ordering.by[Pair, Double](_.y)
order: scala.math.Ordering[Pair] = scala.math.Ordering$$anon$7@3b2e9a90
Run Code Online (Sandbox Code Playgroud)

然后你会发现你的max功能适用于Pairs

scala> max(List(Pair("foo", 1), Pair("bar", 2), Pair("baz", 2.2)))
res5: Pair = Pair(baz,2.2)
Run Code Online (Sandbox Code Playgroud)