Scala 深入浅出实战经典 第58讲:Scala中Abstract Types实战详解

王家林亲授《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_XMTI4ODY0MTQwNA==.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/m/0/y/m0160v09p4y.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-18.
* 第59讲:Scala中隐式转换初体验实战详解以及在Spark中的应用
*/

/**
* 隐身转换函数:以implicit关键词申明带有单个参数的的函数,这种函数被自动应用,从一直值类型转换为另一种类型
* 使用场景: 比如你希望某个类有某种方法,但是这个类的作者没有提供该方法比如:
* java.io.File能有个read方法该多好.
* Scala 可以如下方式来实现
*/

class RichFile(val file:File) {
def read = Source.fromFile(file.getPath()).mkString
}

object Context {
implicit def fileToRichFile(file:File) = new RichFile(file)
}


object Hello_Implicit_Conversations {

def main (args: Array[String]) {

import Context.fileToRichFile
println(new File("path").read)

/**
* 执行流程:
* 1, 先确定自己的作用域, new File在main方法里, 在执行read方法的时候会首先检查是否有隐式转换. 这里import了 fileToRichFile;
* 而且发现该方法的参数和File的类型相同, 所以检查通过. 而且实例化了RichFile. 调用其实例化的方法read.
*/

}

}

  

posted @ 2015-08-18 17:37  曹振华  阅读(453)  评论(0编辑  收藏  举报