代码如下:

/**//*
*Test.java
*
*Createdon2007-10-4,19:32:43
*
*Tochangethistemplate,chooseTools|Templates
*andopenthetemplateintheeditor.
*/


/***//**
*
*@authorJeffery
*/


classBase...{

inti;


Base()...{
add(1);
System.out.println("Base"+this.i);
}


voidadd(inti)...{
this.i+=i;
System.out.println("Baseaddi"+this.i);
}
}


classMyBaseextendsBase...{


MyBase()...{
add(2);
System.out.println("Mybase"+this.i);
}


voidadd(inti)...{
this.i+=i*2;
System.out.println("Mybaseaddi"+this.i);
}
}


publicclassTest...{


publicstaticvoidmain(String[]args)...{
go(newMyBase());
}


staticvoidgo(Baseb)...{
b.add(8);
}
}
最后输出i的值为22
分析:按照之前一篇文章总结在主函数中,首先执行new MyBase(),在这个过程中,子类会首先调用父类的构造函数Base(),但Base()函数执行add()方法时特别需要注意, 这个add方法由于是在新建MyBase对象时调用的,所以将会首先查找MyBase类中是否有此方法。所以Base函数中的add(1)实际上是执行的乘2的方法。

/**//*
*Test.java
*
*Createdon2007-10-4,19:32:43
*
*Tochangethistemplate,chooseTools|Templates
*andopenthetemplateintheeditor.
*/

/***//**
*
*@authorJeffery
*/

classBase...{
inti;

Base()...{
add(1);
System.out.println("Base"+this.i);
}

voidadd(inti)...{
this.i+=i;
System.out.println("Baseaddi"+this.i);
}
}

classMyBaseextendsBase...{

MyBase()...{
add(2);
System.out.println("Mybase"+this.i);
}

voidadd(inti)...{
this.i+=i*2;
System.out.println("Mybaseaddi"+this.i);
}
}

publicclassTest...{

publicstaticvoidmain(String[]args)...{
go(newMyBase());
}

staticvoidgo(Baseb)...{
b.add(8);
}
}
分析:按照之前一篇文章总结在主函数中,首先执行new MyBase(),在这个过程中,子类会首先调用父类的构造函数Base(),但Base()函数执行add()方法时特别需要注意, 这个add方法由于是在新建MyBase对象时调用的,所以将会首先查找MyBase类中是否有此方法。所以Base函数中的add(1)实际上是执行的乘2的方法。
本文通过一个Java继承的例子展示了在创建子类对象过程中父类构造方法的调用顺序及方法覆盖的效果。当子类对象被创建时,父类构造方法先被执行,并尝试调用其内部的add方法。由于子类重写了该方法,导致最终执行了乘2的操作。

被折叠的 条评论
为什么被折叠?



