第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]