Scala 深入浅出实战经典 第65讲:Scala中隐式转换内幕揭秘、最佳实践及其在Spark中的应用源码解析

王家林亲授《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/NGgUD5FBQaA/
优酷:http://v.youku.com/v_show/id_XMTI5MDkxODk5Mg==.html?from=s1.8-1-1.2
爱奇艺:http://www.iqiyi.com/w_19rru5bi79.html#vfrm=2-3-0-1
腾讯视频:http://v.qq.com/boke/page/b/0/j/b0160ksmdyj.html
技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群

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

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

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


package com.parllay.scala.implicits

import java.io.File

import scala.io.Source

/**
* Created by richard on 15-8-22.
* 第65讲:Scala中隐式转换内幕揭秘、最佳实践及其在Spark中的应用源码解析
*/

/**
* 在这里main方法中我们不用使用import 导入, 而是直接new File_Implicits
* 具体执行流程:
* 1, 编译器发现File_Implicits没有read方法.
* 2, 检查类及其伴生对象是否有隐式转换, 在这里有隐式转换
* 3, 检查class的类型是否和implicit def的方法定义的参数类型一致,在这里继承自File
* 4, 然后执行该隐式方法,
* 5, 执行RichFile的read方法.
*/
class Rich1File(val file:File) {
def read = Source.fromFile(file.getPath()).mkString
}

class File_Implicits(path:String) extends File(path)

object File_Implicits {
implicit def fileToRichFile(file:File) = new Rich1File(file)
}

object Implicits_Internal {

def main(args: Array[String]) {
println(new File_Implicits("path").read)
}

}

posted @ 2015-08-25 16:48  曹振华  阅读(387)  评论(0编辑  收藏  举报