Scala 深入浅出实战经典 第60讲:Scala中隐式参数实战详解以及在Spark中的应用源码解析

时间:2022-03-08 23:09:47

王家林亲授《DT大数据梦工厂》大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频、PPT、代码下载:
百度云盘:http://pan.baidu.com/s/1c0noOt6
腾讯微云:http://url.cn/TnGbdC
360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2
土豆:http://www.tudou.com/programs/view/IVN4EuFlmKk/
优酷:http://v.youku.com/v_show/id_XMTI4ODY0OTkyNA==.html?from=s1.8-1-1.2
爱奇艺:http://www.iqiyi.com/w_19rrt570q9.html#vfrm=2-3-0-1
腾讯视频:http://v.qq.com/boke/page/a/0/m/a0160z4i81m.html
技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群

DT大数据梦工厂① :462923555
DT大数据梦工厂②:437123764
DT大数据梦工厂③ :418110145

微信公众账号: DT_Spark
王家林老师微信号: 18610086859
王家林老师QQ: 1740415547
王家林老师邮箱: 18610086859@126.com

本视频由王家林老师, 亲自讲解, 完全通过代码实战把您带人大数据的时代.

package com.parllay.scala.implicits

/**
* Created by richard on 15-8-19.
* 第60讲:Scala中隐式参数实战详解以及在Spark中的应用源码解析
*/

/**
*使用场景: 函数或者方法可以带有一个标记为implicit的参数列表,
* 这种情况下,编译器将会查找缺省值,提供给该函数或者方法.
*
*/
object Context_Implicit{
implicit val default:String = "Java"
}

object Param{
def print(content:String)(implicit language:String): Unit = {
println(content + ":" + language)
}
}

object Implicit_Parameter {

def main(args: Array[String]) {
/**
* 可以用显示的对象来调用print方法, 如下
*/
Param.print("Spark")("Scala")


import Context_Implicit._
/**
* 但是我们也可以隐藏掉隐式参数的调用,如下;
* 这样编译器将会去查找一个类型为implicit的隐式值.必须为被申明为Implicit的值.
* 编译器将会在两个地方查找这样的一个对象.
* 1, 当前作用域所有可以用单个标识符指代的满足类型要求的val和def.
* 2, 与所要求类型项关联的伴生对象. 相关联的类型包括类型本身,以及他的类型参数(如果他是一个参数化类型的话)
*
* 在这里我们有一个伴生对象Param,上面我们以及import, 导入,所以以下语句可以正常编译执行.
*/
Param.print("Hadoop")

}

}