九、scala面向对象编程之继承

一、  extendsjava

二、override 和super

三、override fieldide

四、isInstanceOf和asInstanceOf函数

五、getClass和classOfthis

六、使用模式匹配进行类型判断spa

七、protected

八、调用父类的constructscala

九、匿名内部类3d

十、抽象类对象

十一、抽象fieldblog

一、  extends

  scala中,让子类继承父类,与java同样,也使用extends关键字。继承

  子类能够从父类继承父类的field和method,而后子类能够在本身内部放入父类没有,子类特有的field和method,使用继承能够有效服用代码。

  子类能够覆盖父类的field和method,可是若是父类用final修饰,则该类是没法被继承的; 若是父类的field和method用final修饰,则field和method是没法被覆盖的。

   

二、override 和super

  若是子类要覆盖父类的非抽象方法,则必须许使用override关键字。

  Override关键字能够帮助咱们今早发现代码里的错误,好比override修饰的父类方法的方法名拼写错了,覆盖父类方法的参数咱们写错了,等等。

  子类覆盖父类方法后,若是咱们须要调用父类被覆盖的方法,可使用super关键字,显示的指定要调用的父类的方法

  

三、override field

  Scala中,子类能够覆盖父类的val field,并且子类的val field还能够覆盖父类的val field的getter方法,只要在子类中使用override便可。

   

四、isInstanceOf和asInstanceOf

  若是建立了子类的对象,但又将其赋予了子类类型的变量,后续在程序中,又须要将父类类型的变量转换为子类类型的变量。

  首先,须要使用isInstanceOf判断对象是不是指定类的对象,若是是的话,则可使用asInstanceOf将对象转换为指定类型。

  若是对象是null,则isInstanceOf必定返回false,asInstanceOf必定给返回null。

  若是没有isInstanceOf先判断对象是否为指定类的实例,就直接用asInstanceOf转换,则可能抛出异常。

  

五、getClass和classOf

  isInstanceOf只能判断出对象是不是指定类及其子类的对象,而不能精确判断出,对象就是指定类的对象。

  若是要求精确的判断对象就是指定类的对象,那么就只能使用getClass和classOf了。

  对象.getClass能够精确获取对象的类,classOf[类]能够精确获取类,使用==操做便可判断。

  

六、使用模式匹配进行类型判断

  在实际开发中,大量的使用了模式匹配的方式进行类型的判断,这种方式更加简洁明了,并且代码可维护性和可扩展性也很是高。

  使用模式匹配,功能性上来讲,与isInstanceOf同样,也是判断主要是该类以及该类的子类的对象便可,不是精准判断的。

   

七、protected

  Scala中,可使用protected修饰field和method,这样在子类中就能够不须要super关键字,直接就能够访问field和method。

  可使用protected[this],则只能在当前子类对象中访问父类的field和method,没法经过其余子类对象访问父类的field和method。

  

八、调用父类的construct

  Scala中,每一个类能够有一个主constructor和任意多个辅助constructor,而每一个辅助constructor的第一行都必须是调用其它辅助constructor或者是主constructor,所以子类的辅助constructor是必定不能直接调用父类的constructor的。

  只能在子类的主constructor中调用父类的constructor,如下这种语法,就是经过子类的主构造函数来调用父类的构造函数。

  若是是父类中接受的参数,好比name和age,子类中接受时,就不要用任何val或var来修饰了,不然会认为是子类要覆盖父类的field。

  

  

九、匿名内部类

  Scala中,匿名子类很是常见,并且很是强大,spark源码中使用了大量这种匿名内部类。

  匿名子类就是说能够定义一个类的没有名称的子类,并直接建立其对象,而后将对象的引用赋予一个变量,以后甚至能够将该匿名子类的对象传递给其余函数。

  

十、抽象类

  若是在父类中,某些方法没法当即实现,而须要依赖不一样的子类来覆盖,重写实现本身不一样的方法实现。此时能够将父类中的这些方法不给出具体的实现,只有方法签名,这种方法就是抽象方法。

  若是一个类中有一个抽象方法,那么类就必须用abstract来声明为抽象类,此时抽象类是不能够实例化的。

  在子类中覆盖抽象类的抽象方法时,不须要使用override关键字。

  

十一、抽象field

  若是在父类中,定义了fiield,可是没有给出初始值,则此field为抽象field。

  抽象field意味着,scala会根据本身的规则,为var或val类型的field生成对应的getter和setter方法,可是父类中是没有该field的。

  子类必须覆盖field,以定义本身的具体field,而且覆盖抽象field,不须要使用override关键字。

  

相关文章
相关标签/搜索