标签:
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
Scala中隐式转换内幕操作规则揭秘、最佳实践及其在Spark中的应用源码解析之Scala学习笔记-55
标签:
原文地址:http://www.cnblogs.com/leegh1992/p/4815258.html