我们先看一下变量界定的代码
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) } }
本文出自 “叮咚” 博客,请务必保留此出处http://lqding.blog.51cto.com/9123978/1742156
第44讲:Scala中View Bounds代码实战及其在Spark中的应用源码解析
原文:http://lqding.blog.51cto.com/9123978/1742156