博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Scala学习第九天 Scala的内部类实战详解
阅读量:2200 次
发布时间:2019-05-03

本文共 1131 字,大约阅读时间需要 3 分钟。

信息来源于 DT大数据梦工厂微信公众账号:DT_Spark

DT大数据梦工厂群号:302306504王家林老师微信号:wangjialinandroid

1、Scala内部类

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

class Outer(val name : String) {
outer=> class Inner(val name : String){
//foo方法传递的是Inner类型的参数 def foo(b : Inner) = println(" Outer: " + outer.name + " Innner: " + b.name) }} object OOPInScala{
def main(args: Array[String]){ //构建2个外部类,以"Spark"、"Hadoop"参数传入; val outer1=new Outer("Spark") val outer2=new Outer("Hadoop") val inner1=new outer1.Inner("Scala") val inner2=new outer2.Inner("Java") inner1.foo(inner1) inner2.foo(inner2) } } /*Val的name是外部类outer的成员,在外部类又定义了一个内部类Inner,同样,Val的name是内部类Inner的成员*//*当内部类要访问外部类的话,这个时候,可以给外部类指定一个名称,如上图的outer*/

内部类,Scala与Java的不同:

1)构建内部类的语法是new outer1.Inner(“Scala”),因为内部类是从属于外部类的对象,而在Java中,是outer.new Inner(“Scala”).
为什么Scala这么设计呢?举个简单的场景,比如network中,每个network有自己的成员,不同的社交网络比如”twwiter”,”facebook”,显然,当我们要访问facebook的成员,用new facebook的实例去访问内部的成员更自然。
Scala 深入浅出实战经典(1-64讲)完整视频、PPT、代码下载:

百度云盘:

腾讯微云:

360云盘: 访问密码 45e2

Scala视频及其更新和其他资料(Spark公开课、安卓基础、移动互联网)下载:
百度云盘:

转载地址:http://lerub.baihongyu.com/

你可能感兴趣的文章
(PAT 1061) Dating (字符串处理)
查看>>
(PAT 1118) Birds in Forest (并查集)
查看>>
数据结构 拓扑排序
查看>>
(PAT 1040) Longest Symmetric String (DP-最长回文子串)
查看>>
(PAT 1145) Hashing - Average Search Time (哈希表冲突处理)
查看>>
(1129) Recommendation System 排序
查看>>
PAT1090 Highest Price in Supply Chain 树DFS
查看>>
(PAT 1096) Consecutive Factors (质因子分解)
查看>>
(PAT 1019) General Palindromic Number (进制转换)
查看>>
(PAT 1073) Scientific Notation (字符串模拟题)
查看>>
(PAT 1080) Graduate Admission (排序)
查看>>
Play on Words UVA - 10129 (欧拉路径)
查看>>
mininet+floodlight搭建sdn环境并创建简答topo
查看>>
【linux】nohup和&的作用
查看>>
Set、WeakSet、Map以及WeakMap结构基本知识点
查看>>
【NLP学习笔记】(一)Gensim基本使用方法
查看>>
【NLP学习笔记】(二)gensim使用之Topics and Transformations
查看>>
【深度学习】LSTM的架构及公式
查看>>
【python】re模块常用方法
查看>>
剑指offer 19.二叉树的镜像
查看>>