第44讲:Scala中View Bounds代码实战及其在Spark中的应用源码解析

我们先看一下变量界定的代码

package com.dt.scala.type_parameterization

class Pair_NoPerfect[T <: Comparable[T]](first: T,second:T){ 
  def bigger ={
    if (first.compareTo(second)>=0) first else second 
  }
}

object View_Bounds {
    def main(args: Array[String]): Unit = {
    val pair = new Pair_NoPerfect("Spark","Hadoop")
    println(pair.bigger)
    }
}

如果我们要传入的参数是整数,编译器会报错

第44讲:Scala中View Bounds代码实战及其在Spark中的应用源码解析

说明Int不是Comparable的子类。但是Int可以通过隐式转换转成RichInt ,它是Comparable子类。

那么我们可以使用视图界定(view bound)来实现

package com.dt.scala.type_parameterization

class Pair_NoPerfect[T <: Comparable[T]](first: T,second:T){ 
  def bigger ={
    if (first.compareTo(second)>=0) first else second 
  }
}
// 将变量界定符号中的:换成% ,那么就变成了视图界定  <% 
class Pair_Better[T <% Comparable[T]](first: T,second:T){ 
  def bigger ={
    if (first.compareTo(second)>=0) first else second 
  }
}
object View_Bounds {
    def main(args: Array[String]): Unit = {
       val pair = new Pair_Better(1,2) // 隐式转换 Int -> RichInt 
       println(pair.bigger)
    }
}

原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/194606.html

(0)
上一篇 2021年11月16日
下一篇 2021年11月16日

相关推荐

发表回复

登录后才能评论