您的位置:首页 > 其它

Scala中隐式转换内幕操作规则揭秘、最佳实践及其在Spark中的应用源码解析之Scala学习笔记-55

2015-09-17 08:51 711 查看
package com.leegh.implicits

import scala.io.Source
import java.io.File

/**
* @author Guohui Li
*/
class RicherFile(val file: File) {
def read = Source.fromFile(file.getPath).mkString
}

class File_Implicits(path: String) extends File(path)
//伴生对象
object File_Implicits {
implicit def file2RichFile(file: File) = new RicherFile(file)
}
//编译器执行发现File_Implicits没有read方法,上下文也没有隐式的导入。看下File_Implicits的伴生对象是是否有隐式转换。
//implicit关键字,进行参数类型匹配,发现RicherFile接收相同参数,有read方法
object Implicits_Internals {
def main(args: Array[String]): Unit = {
println(new File_Implicits("E:\\leegh.txt").read)
}
}

附:

本博客说明:

1.整理思路,提高自己。

2.受教于王家林老师,​有所收获,故推荐。

3.博客注重实践,多余的文字就不多说了,都是做技术的。

4.信息来源于 DT大数据梦工厂微信公众账号:DT_Spark。​

DT大数据梦工厂的微信公众号是DT_Spark,每天都会有大数据实战视频发布,请您持续学习。

王家林DT大数据梦工厂scala的所有视频、PPT和代码在百度云盘的链接:http://pan.baidu.com/share/home?uk=4013289088#category/type=0&qq-pf-to=pcqq.group

王家林《Scala深入浅出实战初级入门经典视频课程》http://edu.51cto.com/lesson/id-66538.html

王家林《Scala深入浅出实战中级进阶经典视频课程》http://edu.51cto.com/lesson/id-67139.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: