一、 extendsjava
三、override fieldide
四、isInstanceOf和asInstanceOf函数
五、getClass和classOfthis
六、使用模式匹配进行类型判断spa
八、调用父类的constructscala
九、匿名内部类3d
十、抽象类对象
十一、抽象fieldblog
scala中,让子类继承父类,与java同样,也使用extends关键字。继承
子类能够从父类继承父类的field和method,而后子类能够在本身内部放入父类没有,子类特有的field和method,使用继承能够有效服用代码。
子类能够覆盖父类的field和method,可是若是父类用final修饰,则该类是没法被继承的; 若是父类的field和method用final修饰,则field和method是没法被覆盖的。
若是子类要覆盖父类的非抽象方法,则必须许使用override关键字。
Override关键字能够帮助咱们今早发现代码里的错误,好比override修饰的父类方法的方法名拼写错了,覆盖父类方法的参数咱们写错了,等等。
子类覆盖父类方法后,若是咱们须要调用父类被覆盖的方法,可使用super关键字,显示的指定要调用的父类的方法
Scala中,子类能够覆盖父类的val field,并且子类的val field还能够覆盖父类的val field的getter方法,只要在子类中使用override便可。
若是建立了子类的对象,但又将其赋予了子类类型的变量,后续在程序中,又须要将父类类型的变量转换为子类类型的变量。
首先,须要使用isInstanceOf判断对象是不是指定类的对象,若是是的话,则可使用asInstanceOf将对象转换为指定类型。
若是对象是null,则isInstanceOf必定返回false,asInstanceOf必定给返回null。
若是没有isInstanceOf先判断对象是否为指定类的实例,就直接用asInstanceOf转换,则可能抛出异常。
isInstanceOf只能判断出对象是不是指定类及其子类的对象,而不能精确判断出,对象就是指定类的对象。
若是要求精确的判断对象就是指定类的对象,那么就只能使用getClass和classOf了。
对象.getClass能够精确获取对象的类,classOf[类]能够精确获取类,使用==操做便可判断。
在实际开发中,大量的使用了模式匹配的方式进行类型的判断,这种方式更加简洁明了,并且代码可维护性和可扩展性也很是高。
使用模式匹配,功能性上来讲,与isInstanceOf同样,也是判断主要是该类以及该类的子类的对象便可,不是精准判断的。
Scala中,可使用protected修饰field和method,这样在子类中就能够不须要super关键字,直接就能够访问field和method。
可使用protected[this],则只能在当前子类对象中访问父类的field和method,没法经过其余子类对象访问父类的field和method。
Scala中,每一个类能够有一个主constructor和任意多个辅助constructor,而每一个辅助constructor的第一行都必须是调用其它辅助constructor或者是主constructor,所以子类的辅助constructor是必定不能直接调用父类的constructor的。
只能在子类的主constructor中调用父类的constructor,如下这种语法,就是经过子类的主构造函数来调用父类的构造函数。
若是是父类中接受的参数,好比name和age,子类中接受时,就不要用任何val或var来修饰了,不然会认为是子类要覆盖父类的field。
Scala中,匿名子类很是常见,并且很是强大,spark源码中使用了大量这种匿名内部类。
匿名子类就是说能够定义一个类的没有名称的子类,并直接建立其对象,而后将对象的引用赋予一个变量,以后甚至能够将该匿名子类的对象传递给其余函数。
若是在父类中,某些方法没法当即实现,而须要依赖不一样的子类来覆盖,重写实现本身不一样的方法实现。此时能够将父类中的这些方法不给出具体的实现,只有方法签名,这种方法就是抽象方法。
若是一个类中有一个抽象方法,那么类就必须用abstract来声明为抽象类,此时抽象类是不能够实例化的。
在子类中覆盖抽象类的抽象方法时,不须要使用override关键字。
若是在父类中,定义了fiield,可是没有给出初始值,则此field为抽象field。
抽象field意味着,scala会根据本身的规则,为var或val类型的field生成对应的getter和setter方法,可是父类中是没有该field的。
子类必须覆盖field,以定义本身的具体field,而且覆盖抽象field,不须要使用override关键字。