千家信息网

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

发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,我们先看一下变量界定的代码package com.dt.scala.type_parameterizationclass Pair_NoPerfect[T <: Comparable[T]](firs
千家信息网最后更新 2025年01月22日第44讲:Scala中View Bounds代码实战及其在Spark中的应用源码解析

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

package com.dt.scala.type_parameterizationclass 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)    }}

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

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

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

package com.dt.scala.type_parameterizationclass 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)    }}


0