Scala 深入浅出实战经典 第9讲:Scala的内部类实战详解

一、课程前导
DT大数据梦工厂的微信公众号是DT_Spark,每天都会有大数据实战视频发布,请您持续学习。
Scala 深入浅出实战经典(1-81讲)完整视频、PPT、代码下载:
百度云盘:http://pan.baidu.com/s/1c0noOt6
腾讯微云:http://url.cn/TnGbdC
360云盘:http://yunpan.cn/cQ4c2UALDjSKy  访问密码 45e2
Scala是最为重要的大数据语言,该视频每天还在持续跟新中,预计大约有140讲,请您根据上述视频彻底掌握Scala实战技术。

《第9讲:Scala的内部类实战详解》的视频地址:
酷6:http://v.ku6.com/show/wCSc0mfaKvT1s1rferBfCQ...html
51cto:http://www.56.com/u35/v_MTM3NjQxNDQw.html

最后,王家林老师个人的微信是18610086859

二、课程内容
注:下面的笔记源于王家林老师的第9讲:Scala的内部类实战详解视频和《快速Scala》书。
第9讲:Scala的内部类实战详解
1、Scala内部类

与Java的内部类有很大不同,Java的内部类其实是从属于外部类,而Scala的内部类是从属于对象的。这可以从下面的实例看出:

 


(1)Val的name是外部类outer的成员,在外部类又定义了一个内部类Inner,同样,Val的name是内部类Inner的成员

(2)当内部类要访问外部类的话,这个时候,可以给外部类指定一个名称,如上图的outer

(3)foo方法传递的是Inner类型的参数

(4)构建2个外部类,以"Spark"、"Hadoop"参数传入;

(5)构建内部类的语法是new outer1.Inner("Scala"),因为内部类是从属于外部类的对象,而在Java中,是outer.new Inner("Scala").为什么Scala这么设计呢?举个简单的场景,比如network中,每个network有自己的成员,不同的社交网络比如"twwiter","facebook",显然,当我们要访问facebook的成员,用new facebook的实例去访问内部的成员更自然。

(6)在Scala中inner1.foo(inner2)是不可以的,但在Java是可以的,这是scala与java的不同,scala更符合实际的情况,如果构建一个类,成员之间要共享,要构建java一样的内部类系统,可以把成员放在object中。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值