第59讲:Scala中隐式转换初体验实战详解以及隐式转换在Spark中的应用源码解析学习笔记
隐式转换或隐式参数都是为了增强类库功能的方式。
在java/C#中增强类库功能的方式只是使用工具类或继承的方式,scala中是隐式转换或隐式参数的方式。
隐式转换可以把一个类的实例当作另一个类的实例。
从使用者角度使用者用的是当前的类,其实却用的是另一个类的方法。
不需要修改原来的类就可以把新方法附着到原来的类上。
对代码重构非常重要。
1 to 3
整数本身是没有to方法的,但predef中有把整数隐式转换成RichInt,就有to方法了。
predef中有很多默认做的隐式转换的内容。
隐式参数与隐式转换不同
clas RichFile(val file:File){
def read = Source.formFile(file.getPath()).mkString
}
object Context{
implicit def file2RichFile(file:File)= new RichFile(file)
//光定义是不够的必须说明转换途径。
}
object Hello_Implicit_Conversions {
def main(args: Array[String]){
import Context.file2RichFile
println(new File("E:\\WangJialin.txt").read)
//file类本身没有read方法,通过隐式转换成RichFile后就有read方法了。
}
}
总结:
需要一个类的某个方法,但这个类没有这个方法,那么就把这个类转换成一个增强的类,这个增强的类里有需要的这个方法。
隐式转换函数的功能就是把已有的类型转换成增强的类型。
scala一次只会应用一个隐式转换。
如果在当前范围找到了隐式转换的方式就不会再去别的地方找了。
隐式参数有更复杂的内容。
隐式转换查找先在当前作用域查找,如果找不到会到源或目标类型的伴生对象中。
以上内容是从王家林老师DT大数据课程第59讲的学习笔记。
DT大数据微信公众账号:DT_Spark
王家林老师QQ:1740415547
王家林老师微信号:18610086859
百度网盘共享的DT大数据梦工厂王家林老师第1-91讲的视频内容:http://pan.baidu.com/share/home?uk=4013289088#category/type=0&qq-pf-to=pcqq.group
第56讲视频网站:
51CTO视频:http://edu.51cto.com/lesson/id-68942.html