方法一:使用隐式转换函数:相当于java中的 java.lang.Comparable
def myCompare[T]( x: T, y : T)(implicit z : T => Ordered[T]) : T = {
if(x.compare(y) > 0) y
else x
}
方法二:使用隐式转换参数,当于于java中的 java.util.Comprator,所以它也一般需要在一个类中
class Pair[T](val x : T, val y : T){
def smaller(implicit t : Ordering[T]) : T ={
if(t.compare(x, y) > 0) y
else x
}
}
但以上两种方法都有一个要求,就是T需要实现 Comparable或者 Comparable(ordering,Ordered),于是我们如果针对于没有实现这个类的,需要做如下处理:
如果T对象为如下的User对象:
class User{
val id : Int = _
var name : String = _
}
方法一,在需要处理的T对象的Object元型中添加如下:
object User{
implicit def order[T <: User] : Ordering[T] = Ordering.by(_.id)
}
方法二:同样是在T对象的object中添加:
object User{
implicit def order[T <: User] : Ordering[T] = new Ordering[T](){
override def compare(x : T, y : T):Int = {
x.id - y.id
}
}
}
Scala 实现两个类型比较的实现
最新推荐文章于 2022-09-23 08:42:10 发布