第14讲-Scala编程详解面向对象编程之继承.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
北风网项目实战培训 // Scala中,让子类继承父类,与Java一样,也是使用extends关键字 // 继承就代表,子类可以从父类继承父类的field和method;然后子类可以在自己内部放入父类所没有,子类特有的field和method;使用继承可以有效复用代码 // 子类可以覆盖父类的field和method;但是如果父类用final修饰,field和method用final修饰,则该类是无法被继承的,field和method是无法被覆盖的 class Person { private var name = leo def getName = name } class Student extends Person { private var score = A def getScore = score } extends // Scala中,如果子类要覆盖一个父类中的非抽象方法,则必须使用override关键字 // override关键字可以帮助我们尽早地发现代码里的错误,比如:override修饰的父类方法的方法名我们拼写错了;比如要覆盖的父类方法的参数我们写错了;等等 // 此外,在子类覆盖父类方法之后,如果我们在子类中就是要调用父类的被覆盖的方法呢?那就可以使用super关键字,显式地指定要调用父类的方法 class Person { private var name = leo def getName = name } class Student extends Person { private var score = A def getScore = score override def getName = Hi, Im + super.getName } override和super // Scala中,子类可以覆盖父类的val field,而且子类的val field还可以覆盖父类的val field的getter方法;只要在子类中使用override关键字即可 class Person { val name: String = Person def age: Int = 0 } class Student extends Person { override val name: String = leo override val age: Int = 30 } override field // 如果我们创建了子类的对象,但是又将其赋予了父类类型的变量。则在后续的程序中,我们又需要将父类类型的变量转换为子类类型的变量,应该如何做? // 首先,需要使用isInstanceOf判断对象是否是指定类的对象,如果是的话,则可以使用asInstanceOf将对象转换为指定类型 // 注意,如果对象是null,则isInstanceOf一定返回false,asInstanceOf一定返回null // 注意,如果没有用isInstanceOf先判断对象是否为指定类的实例,就直接用asInstanceOf转换,则可能会抛出异常 class Person class Student extends Person val p: Person = new Student var s: Student = null if (p.isInstanceOf[Student]) s = p.asInstanceOf[Student] isInstanceOf和asInstanceOf // isInstanceOf只能判断出对象是否是指定类以及其子类的对象,而不能精确判断出,对象就是指定类的对象 // 如果要求精确地判断对象就是指定类的对象,那么就只能使用getClass和classOf了 // 对象.getClass可以精确获取对象的类,classOf[类]可以精确获取类,然后使用==操作符即可判断 class Person class Student extends Person val p: Person = new Student p.isInstanceOf[Person] p.getClass == classOf[Person] p.getClass == classOf[Student] getClass和classOf // 但是在实际开发中,比如spark的源码中,大量的地方都是使用了模式匹配的方式来进行类型的判断,这种方式更加地简洁明了,而且代码得可维护性和可扩展性也非常的高 // 使用模式匹配,功能性上来说,与isInstanceOf一样,也是判

文档评论(0)

a13355589 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档