Posted on 2006-10-11 20:17
久城 阅读(253)
评论(0) 编辑 收藏 所属分类:
JavaTest
曾经遇到过这样一个小问题:
class A {
private int i=1;
public int getI(){
return i;
}
public void setI(int i){
this.i=i;
}
}
public class B extends A {
int i=2;
public static void main (String [] args) {
B b = new B();
System.out.println(b.getI());
}
}
结果是1,而不是2.
这个问题感觉还不错。
1.并不是private成员不会被继承.事实上子类可以继承父类的任何变量和方法。private、protected只是访问权限而已。即使i是public的
输出结果也肯定是1.
2.方法可以覆盖,成员变量并没有覆盖一说,也就是子类的i和父类的i是共存在子类体内的。父类对象中有i变量、set get两个方法。子类class中应有i【继承于父类对象】、i【子类对象】两个变量、set get两个方法【继承于父类对象】。
3.java中的原则是调用的是哪个类的方法,那么这个方法访问的就是这个类中的成员。子类中没有覆盖public int getI()这个方法的话,那么子类调用的其实是父类的getI()方法.所以返回的是父类中的i.
所以如果子类覆盖了getI()方法,那么就会输出的是子类中的i了,因为调用的是子类中的方法。
以上是我曾经遇到的一个问题,今天遇到另一个例子,进而进行思考!
class A{
public int m = 1;
A(){
System.out.println("A have construct");
System.out.println(m);
tt();//因为tt()方法已经被覆盖,所以此处调用的是子类的tt()方法;
//子类的数据成员此时还未显式的初始化,所以返回值为默认的0;
}
public void tt(){
System.out.println(m);
}
}
public class B extends A{
public int n = 2;
B(){
System.out.println("B have construct");
System.out.println(n);
tt();
}
public void tt(){
System.out.println(n);
}
public static void main(String args[]){
B b = new B();
}
}
输出结果是:
A have construct
1
0
B have construct
2
2
如注释部分的解说!
这个例子中,B中的tt()方法已经覆盖了父类中的tt()方法.所以在执行父类的构造方法时,调用的是子类的tt()方法;
PS:
构造一个对象的过程是:
先父类,后子类;
先成员变量初始化,后构造函数.
欢迎来访!^.^!
本BLOG仅用于个人学习交流!
目的在于记录个人成长.
所有文字均属于个人理解.
如有错误,望多多指教!不胜感激!