首页 > 其他 > 详细

第59讲:Scala中隐式转换初体验

时间:2015-09-17 01:06:05      阅读:199      评论:0      收藏:0      [点我收藏+]

今天学习了下隐式转换的内容。所谓隐式转换,就是说,一个实例拥用1 2 3方法,但是当它需要4方法的时候,它没有,但是却可以通过转换成另一种类型来调用4方法,而且这种转换是自动转换不需要人为干预的,这种形为就叫做隐式转换。让我们通过实例来分析一下:

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


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

object Context{
  implicit def file2RickFile(file:File) = new RichFile(file)//将File转换成RichFile
}

object test59 {
  def main(args:Array[String]){
    import Context.file2RickFile
    println (new File("E:\\text.txt").read)
  }
}

 

首先,我们定义一个class RichFile,当的参数类型是File,类拥有read方法。

然后定义一个单例对像Context,它拥有一个隐式方法,file2RichFile,此方法会将File类型的file传给类RichFile,实例化成RichFile的对像。

然后在main方法中,我们导入此方法。

接着,我们新建一个File类型的对像,让它去调用read方法。但是此file没有read方法,这时,编译器会在main方法体内寻找可以实现read方法的方法,也就是file2RichFile,通过此方法,将file实例化成RichFile的对像,这时,RichFile类型的file就拥有了read方法,可以正常调用了。

 

分享下更多的scala资源吧:

1,《Scala深入浅出实战经典》http://pan.baidu.com/s/1pJnAUr5
2,《Spark纯实战公益大讲坛》http://pan.baidu.com/s/1sLeVk
3,《Docker公益大讲坛》http://pan.baidu.com/s/1hq0GztU
4,《spark亚太研究院spark公益大讲堂》http://pan.baidu.com/s/1i30Ewsd

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

第59讲:Scala中隐式转换初体验

原文:http://www.cnblogs.com/qingyuesama/p/4815035.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!