(七)类、超类和子类 ——(多态,动态绑定,final类,类型转换,抽象类)

java中所有的继承都是公有继承

在子类中的构造其内可以初始化超类的公有域,但不能初始化超类的私有域。

因此需要在子类构造前的第一行使用super()语句初始化超类的私有域。

如果超类没有不带参数的构造器,而子类没有显式的调用超类的其他构造器,则会出现编译错误。因为编译器无法调用超类的默认构造器。

 

多态

A为超类,B为子类。则A的变量既可以引用A类的对象,也可以引用B类的对象。

动态绑定

当调用x.f(param)时,若x为C类的对象。

一:编译器列举C类中所有的名为f的方法和其超类中访问属性为public名为f的方法。

二:根据参数类型查找匹配的参数对应的方法,此时获的需要调用的方法和参数类型

三:如果是private方法,static方法,final方法,则编译器可以确定调用的时具体哪一个,这时称为静态绑定。与此对应的是,调用的方法依赖于调用对象的实际类型,并且在运行时动态绑定。

比如:b.get(),如果b是A类型,则调用A的方法,如果b是B类型,则调用B的方法

四:程序运行时,并且采用动态绑定调用方法时,虚拟机调用与x所引用对象的实际类型最合适的方法。

比如:b.get(),如果B类没有该方法,则去B的超类查找。

注意:如果B类有一个private的get()方法,尽管b.get()不能调用这个私有的get()方法,也不会取超类寻找。这是因为超类中的方法不能被子类的private方法覆盖,所以子类有一个private的get()方法,说明超类一定没有这个方法。

因为Object有一个toString方法,因此任何类内都不能有private的toString()方法。

阻止继承

final修饰的类不能有子类,因而不能有方法被覆盖,所以其方法也都是final的。

final修饰的方法不能被覆盖。

强制类型转换

1. 只能在继承层次内进行类型转换

2. 在将超类转换成子类之前,应该使用instanceof进行检查

抽象类

抽象类不能被实例化。

可以定义一个抽象类变量,它只能引用非抽象子类的对象。

抽象类可以包含抽象方法,具体方法和具体数据,其中抽象方法的实现在子类中。

如果子类实现了全部抽象方法,则子类便不是抽象的了。反之,子类也必须标记为抽象的。

受保护访问

private:仅对本类可见

public:对所有类可见

protected:对本包和子类可见

无:对本包可见

posted @ 2016-10-14 16:45  且听风吟-wuchao  阅读(635)  评论(0编辑  收藏  举报