Scala 深入淺出實戰經典 第45講: scala中context bounds程式碼例項

weixin_33860553發表於2015-07-30

王家林親授《DT大資料夢工廠》大資料實戰視訊 Scala 深入淺出實戰經典(1-64講)完整視訊、PPT、程式碼下載:
百度雲盤:http://pan.baidu.com/s/1c0noOt6
騰訊微雲:http://url.cn/TnGbdC
360雲盤:http://yunpan.cn/cQ4c2UALDjSKy 訪問密碼 45e2
技術愛好者尤其是大資料愛好者 可以加DT大資料夢工廠的qq群

DT大資料夢工廠① :462923555
DT大資料夢工廠②:437123764
DT大資料夢工廠③ :418110145

微信公眾賬號: DT_Spark
王家林老師微訊號: 18610086859
王家林老師QQ: 1740415547
王家林老師郵箱: 18610086859@126.com

本視訊由王家林老師, 親自講解, 完全通過程式碼實戰把您帶人大資料的時代.

package com.parllay.scala.type_parameterizitor

/**
* Created by richard on 15-7-29.
* Scala 深入淺出實戰經典 第45講: scala中context bounds程式碼例項
*/

/**
* 上下文界定的形式為 T : M, 其中M 必須為泛型類, 必須存在一個M[T]的隱式值.
* 以下類必須存在一個隱式值 Ordering[T], 該隱式值可以用在該類的方法當中,
* 當宣告一個使用隱式值的方法的時候, 需要新增一個"隱式引數"
* ord為:隱式引數
* Ordering[T]為:隱式值
* 隱式值比隱式轉換更靈活
* @param first
* @param second
* @tparam T
*/
class Pair_Context[T : Ordering](val first: T, val second: T){
def smaller(implicit ord: Ordering[T]) =
if(ord.compare(first, second) < 0) first else second
}

object Context_Bound {

def main(args: Array[String]) {

val pair = new Pair_Context("Spark", "Hadoop")
println(pair.smaller)

val int = new Pair_Context(3, 5)
println(int.smaller)

}

}

  

相關文章