Scala学习第九天 Scala的内部类实战详解

信息来源于 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、代码下载:

百度云盘:http://pan.baidu.com/s/1c0noOt6

腾讯微云:http://url.cn/TnGbdC

360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2
Scala视频及其更新和其他资料(Spark公开课、安卓基础、移动互联网)下载:
百度云盘:http://pan.baidu.com/share/home?uk=4013289088&view=share#category/type=0

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值