Scala 学习(4)之「类——基本概念2」

内部类

import scala.collection.mutable.ArrayBuffer
class Class {
	class Student(val name: String) {}		//此处为内部类
	val students = new ArrayBuffer[Student]
	def getStudent(name: String) = {
		new Student(name)
	}
}

val c1 = new Class
val s1 = c1.getStudent("0mifang")
c1.students += s1

val c2 = new Class
val s2 = c2.getStudent("0mifang1")
c1.students += s2		//错误的演示

extends

  • 继承就代表子类可以从父类继承父类的 field 和 method ;然后子类可以在自己内部放入父类所没有,子类特有的 field 和 method,使用继承可以有效复用代码。
  • 子类可以覆盖父类的 field 和 method,但是如果父类用 final 修饰,field 和 method 用 final 修饰,则该类是无法被继承的,field 和 method 是无法被覆盖的。
class Person {
	private var name = "0mifang"
	def getName = name
}
class Student extends Person {
	private var score = "A"
	def getScore = score
}

var student = new Student
student.getName

override和super

  • 如果子类要覆盖一个父类中的非抽象方法,则必须使用 override 关键字 override
  • 关键字可以帮助我们尽早地发现代码里的错误,比如:override 修饰的父类方法的方法名我们拼写错了;比如要覆盖的父类方法的参数我们写错了;等等
  • 此外,在子类覆盖父类方法之后,如果我们在子类中就是要调用父类的被覆盖的方法,那就可以使用 super 关键字,显式地指定要调用父类的方法
class Person {
	private var name = "0mifang"
	def getName = name

}
class Student extends Person {
	private var score = "A"
	def getScore = score

	override def getName = "Hi, I'm " + super.getName
}

var student = new Student
student.getName		// 可以发现,student 类继承了 Person 类的 getName 方法

override field

子类可以覆盖父类的 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 = "0mifang"
	override val age: Int = 18
}

val person = new Person
val student = new Student
person.name
person.age
student.name
student.age

isInstanceOf和asInstanceOf

如果我们创建了子类的对象,但是又将其赋予了父类类型的变量。则在后续的程序中,我们又需要将父类类型的变量转换为子类类型的变量,应该如何做?
首先,需要使用 isInstanceOf 判断对象是否是指定类的对象,如果是的话,则可以使用 asInstanceOf 将对象转换为指定类型。

  • 如果对象是 null,则 isInstanceOf 一定返回 false,asInstanceOf 一定返回null;
  • 如果没有用 isInstanceOf 先判断对象是否为指定类的实例,就直接用 asInstanceOf 转换,则可能会抛出异常。
class Person
class Student extends Person
val p: Person =  new Student
var s: Student = null
// 如果 p 是 Student 类,则让 s 指向 p 转换为 Student 的对象
if (p.isInstanceOf[Student]) s = p.asInstanceOf[Student]

在这里插入图片描述

getClass和classOf

  • isInstanceOf 只能判断出对象是否是指定类以及其子类的对象,而不能精确判断出,对象就是指定类的对象;
  • 对象.getClass 可以精确获取对象的类,classOf[类] 可以精确获取类,然后使用 == 操作符即可判断。
class Person
class Student extends Person

val p: Person = new Student
p.isInstanceOf[Person]			//true
p.getClass == classOf[Person]	//false
p.getClass == classOf[Student]	//true




在这里插入图片描述
欢迎关注,本号将持续分享本人在编程路上的各种见闻。

posted @ 2020-01-22 11:06  0的幂方  阅读(334)  评论(0编辑  收藏  举报