关于继承中变量和方法的覆盖:
1, 与基类中同名的变量,会被派生类所覆盖(同时存在但是有独立的值),直接取值将是派生类的值,但是基类的变量也是同时存在的。如果通过派生类函数访问,得到派生类的值。如果通过从基类继承的方法访问,得到基类的值。如果通过基类的变量,但是实际类型是派生类,得到的将是基类的值。
2,与基类中同名的方法,如果签名完全一致,会覆盖基类的方法。同时在基类中与派生类同名,但是签名不同的函数并不会被覆盖(这与C++不同,C++中名字相同就会全部覆盖,而不管签名是否一致)。通过@Override可以显示指定派生类的函数为覆盖基类同签名的函数,如果没有同签名函数则报错,避免本来想覆盖,结果变成了重载。另外,不能用static方法覆盖非static方法,反之也不可以。
以下是一个例子:
package LearnJava;
/**
* Created by Jimmy on 2015/5/29.
*/
class BaseClass{
int x;
void printvar(){
System.out.println("printvar(): x is: " + x);
}
void mf1(){
System.out.println("BaseClass.mf1()");
}
void mf1(int i){
System.out.println("BaseClass.mf1(int)");
}
void mf2(){
System.out.println("BaseClass.mf2()");
}
}
class DerivedClass extends BaseClass{
float x;
void printvar(){
System.out.println("printvar(): x is: " + x);
System.out.println("printvar(): super.x is: " + super.x);
}
void mf1(){
System.out.println("DerivedClass.mf1()");
}
void mf4(){
System.out.println("DerivedClass.mf4()");
}
}
public class Inherit {
public static void main(String[] args){
//基类的成员变量
BaseClass bc = new BaseClass();
System.out.println("BaseClass.x is: " + bc.x);
//派生类的成员变量
DerivedClass dc = new DerivedClass();
System.out.println("DerivedClass.x is: " + dc.x);
dc.mf2();
dc.mf4();
//派生类的成员变量和super访问的基类成员变量
dc.printvar();
//基类的成员变量
BaseClass bchandler = new DerivedClass();
System.out.println("BaseClass handler x is: " + bchandler.x);
bchandler.mf1();
bchandler.mf1(4);
}
}
执行结果是:
BaseClass.x is: 0 //基类为int
DerivedClass.x is: 0.0 //派生类为float
BaseClass.mf2() //调用继承自基类的函数
DerivedClass.mf4() //调用派生类自己实现的函数
printvar(): x is: 0.0 //派生类的函数取得的成员变量为派生类的
printvar(): super.x is: 0 //也可以通过super取得基类的成员变量
BaseClass handler x is: 0 //通过基类的句柄,一样取得的是基类的成员变量
DerivedClass.mf1() //派生类的方法覆盖了基类的方法
BaseClass.mf1(int) //同时基类的重载函数被继承了下来
打印信息: