第59讲:Scala中隐式转换初体验实战详解以及隐式转换在Spark中的应用源码解析学习笔记

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值