一个小问题引发的思考

Posted on 2006-10-11 20:17 久城 阅读(255) 评论(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仅用于个人学习交流!
目的在于记录个人成长.
所有文字均属于个人理解.
如有错误,望多多指教!不胜感激!


只有注册用户登录后才能发表评论。


网站导航:
 

Copyright © 久城