您的位置:首页 > 编程语言

Scala深入浅出进阶经典 第51讲:Scala中链式调用风格的实现代码实战及其在Spark编程中的广泛运用

2015-09-25 23:11 495 查看
package com.dt.scalaInAction.demo_051

/**
* Scala中链式调用风格的实现代码实战及其在Spark编程中的广泛运用
*/

//1
class Animal {
def breathe : this.type = this
}
class Cat extends Animal {
def eat : this.type = this
}

//2
/*class Animal {
def breathe  = this
}
class Cat extends Animal {
def eat  = this
}*/

object Singleton_Type {
def main(args: Array[String]): Unit = {

val cat = new Cat

/*
* 代码2 报错
* cat.breathe 返回的是Animal的this Animal实例没有eat方法 所以报错
*/
/*
* 为了到达链式调用 采用代码1
* 注意:this.type = this
*
* Q:type是指什么?
* A:在Scala中 任何类对象都有一个type属性
*
* 当执行cat.breathe其实返回的Cat类实例的type 而这个type有eat方法
*/
println(cat.breathe)
}
}

以上内容是从王家林老师DT大数据课程第51讲的学习笔记和个人整理。

DT大数据微信公众账号:DT_Spark

王家林老师QQ:1740415547

王家林老师微信号:18610086859

第51讲视频网站地址:http://pan.baidu.com/s/1eQGqzEa
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: