我们先看一下变量界定的代码
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)
}
}
如果我们要传入的参数是整数,编译器会报错
说明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)
}
}
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。