liukun2009 发表于 2019-1-31 06:26:40

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

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

package com.dt.scala.type_parameterization
class Pair_NoPerfect[T =0) first else second
}
}
object View_Bounds {
    def main(args: Array): Unit = {
    val pair = new Pair_NoPerfect("Spark","Hadoop")
    println(pair.bigger)
    }
}  如果我们要传入的参数是整数,编译器会报错
http://s4.运维网.com/wyfs02/M00/7A/E3/wKioL1bBiYmQXEXXAAAR9dYl23s419.png
  说明Int不是Comparable的子类。但是Int可以通过隐式转换转成RichInt ,它是Comparable子类。
  那么我们可以使用视图界定(view bound)来实现
package com.dt.scala.type_parameterization
class Pair_NoPerfect[T =0) first else second
}
}
// 将变量界定符号中的:换成% ,那么就变成了视图界定   RichInt
       println(pair.bigger)
    }
}  




页: [1]
查看完整版本: 第44讲:Scala中View Bounds代码实战及其在Spark中的应用源码解析