// Scala中,让子类继承父类,与Java一样,也是使用extends关键字// 继承就代表,子类可以从父类继承父类的field和method;然后子类可以在自己内部放入父类所没有,子类特有的field和method;使用继承可以有效复用代码// 子类可以覆盖父类的field和method;但是如果父类用final修饰,field和method用final修饰,则该类是无法被继承的,field和method是无法被覆盖的classPerson{private var name ="leo"
def getName = name
}classStudentextendsPerson{private var score ="A"
def getScore = score
}
override和super
// Scala中,如果子类要覆盖一个父类中的非抽象方法,则必须使用override关键字// override关键字可以帮助我们尽早地发现代码里的错误,比如:override修饰的父类方法的方法名我们拼写错了;比如要覆盖的父类方法的参数我们写错了;等等// 此外,在子类覆盖父类方法之后,如果我们在子类中就是要调用父类的被覆盖的方法呢?那就可以使用super关键字,显式地指定要调用父类的方法classPerson{private var name ="leo"
def getName = name
}classStudentextendsPerson{private var score ="A"
def getScore = score
override def getName ="Hi, I'm "+super.getName
}
override field
// Scala中,子类可以覆盖父类的val field,而且子类的val field还可以覆盖父类的val field的getter方法;只要在子类中使用override关键字即可classPerson{
val name: String ="Person"
def age: Int =0}classStudentextendsPerson{
override val name: String ="leo"
override val age: Int =30}
isInstanceOf和asInstanceOf
// 如果我们创建了子类的对象,但是又将其赋予了父类类型的变量。则在后续的程序中,我们又需要将父类类型的变量转换为子类类型的变量,应该如何做?// 首先,需要使用isInstanceOf判断对象是否是指定类的对象,如果是的话,则可以使用asInstanceOf将对象转换为指定类型// 注意,如果对象是null,则isInstanceOf一定返回false,asInstanceOf一定返回null// 注意,如果没有用isInstanceOf先判断对象是否为指定类的实例,就直接用asInstanceOf转换,则可能会抛出异常classPersonclassStudentextendsPerson
val p: Person =newStudent
var s: Student = null
if(p.isInstanceOf[Student]) s = p.asInstanceOf[Student]
getClass和classOf
// 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]
使用模式匹配进行类型判断
// 但是在实际开发中,比如spark的源码中,大量的地方都是使用了模式匹配的方式来进行类型的判断,这种方式更加地简洁明了,而且代码得可维护性和可扩展性也非常的高// 使用模式匹配,功能性上来说,与isInstanceOf一样,也是判断主要是该类以及该类的子类的对象即可,不是精准判断的classPersonclassStudentextendsPerson
val p: Person =newStudent
p match {case per: Person =>println("it's Person's object")case _ =>println("unknown type")}
protected
// 跟java一样,scala中同样可以使用protected关键字来修饰field和method,这样在子类中就不需要super关键字,直接就可以访问field和method// 还可以使用protected[this],则只能在当前子类对象中访问父类的field和method,无法通过其他子类对象访问父类的field和methodclassPerson{protected var name: String ="leo"protected[this] var hobby: String ="game"}classStudentextendsPerson{
def sayHello =println("Hello, "+ name)
def makeFriends(s: Student){println("my hobby is "+ hobby +", your hobby is "+ s.hobby)}}