Java程序初始化过程中方法覆盖问题

本文通过一个Java继承的例子展示了在创建子类对象过程中父类构造方法的调用顺序及方法覆盖的效果。当子类对象被创建时,父类构造方法先被执行,并尝试调用其内部的add方法。由于子类重写了该方法,导致最终执行了乘2的操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码如下:
/**//*
*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的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值