部分文章内容为公开资料查询整理,原文出处可能未标注,如有侵权,请联系我,谢谢。邮箱地址:gnivor@163.com ►►►需要气球么?请点击我吧!

Scala学习笔记--上界(<:)、视图界定(<%)、上下文界定(T:M)

上界 下界 视界

 

object Test{
  def main(args:Array[String]):Unit={
    def mulBy(factor:Double)=(x:Double)=>factor*x
    val triple =mulBy(3);
    println(triple(10))
    println(mulBy(3)(5))
    
    val p1 = new Pair("dd","ee");
    println(p1.smaller)
    
    //val p2 = new Pair(1,2); //不可以这么用    
    val p2 = new Pair2(1,2); //使用视图界定,可以
    println(p2.smaller)
    
    val p3 = new Pair3(1,2);
    println(p3.smaller)
  }
}

//-----------------上界----------------
class Pair[T<:Comparable[T]] (val first:T,val second :T){
  def smaller = if(first.compareTo(second)<0) first else second
} 


//---------------视图界定---------------
/*
 * 如果试着new一个Pair(4,2),编译器会提示Int不是Comparable[Int]的子类型。
 * 和java.long.Integer包装类型不同,Scala的Int类型没有实现Comparable。
 * 不过,RichInt实现了Comparable[Int],同时还有一个从Int到RichInt的隐式转换
 */
//视图界定
class Pair2[T<% Comparable[T]](val first:T,val second:T){
  def smaller = if(first.compareTo(second)<0) first else second
}
/*
 * 用Ordered特质会更好,它在Comparable的基础上额外提供了关系操作符
 * */
class Pair22[T<% Ordered[T]](val first:T,val second:T){
  def smaller = if(first<second) first else second
}
/*上界没有这样做因为java.lang.String实现了Comparable[String],
 * 但没有实现Ordered[String]。有了视图界定,这就不是问题。
 * 字符串可以被隐式转换成RichString,而RichString是Ordered[String]的子类型
 * */

//--------------------上下文界定----------------------
/*
 * 视图界定T<%V 要求必须存在一个从T到V的隐式转换。
 * 上下文界定的形式为T:M, 其中M是另一个泛型类,它要求必须存在一个类型为M[T]的“隐形值”
 * 例如 class Pair[T: Ordering]
 * 上述定义要求必须存在一个类型为Ordering[T]的隐式值。 该隐式值可以被用在该类的方法中
 * 当你声明一个使用隐式值的方法时,需要添加一个"隐式参数" * 
 */
class Pair3[T:Ordering](val first:T,val second : T){
  def smaller(implicit ord: Ordering[T])=
    if(ord.compare(first,second)<0) first else second
}
 

 

posted @ 2014-12-27 21:50  流了个火  阅读(1806)  评论(0编辑  收藏  举报
►►►需要气球么?请点击我吧!►►►
View My Stats