java中方法到重写

重写:子父类之间,子类出现与父类一模一样到方法,函数的返回值,函数名,参数列表都相同.

注意:

1.子类重写父类到方法,子类重写的方法访问权限要大于或等于父类权限

2.重写方法不能抛出新的异常或者比被重写方法声明的检查异常更广的检查异常。但是可以抛出更少,更有限或者不抛出异常

3.父类方法不抛异常,重写到方法就不能抛异常.

4.不能继承到方法,是不能重写的,比如private

5.final修饰到方法,是不能重写的

6.在子类中重写父类的static方法,是不会报错的,编译也可以通过,但是在通过一个声明为父类,实际类型为子类的引用变量调用该方法时,发现被调用的仍是父类中原本以为会被覆盖的方法,不具有“多态”特性。描述有点绕,看下面的例子:

父类Hero:有一个static的battleWin()方法

子类ADHero:“重写”了父类的battleWin()方法

测试:

测试结果发现,Hero h=new ADHero();h.battleWin();仍旧调用的是父类的battleWin方法,没有实现所谓的“多态”。

结论:父类的static方法是不会被重写的。

解释:在进行方法调用时,系统唯一的任务是确定被调用方法的版本。对于private、static、final方法或者构造器,这部分方法在程序真正运行之前就有一个可以确定的调用版本,并且该版本在运行期间是不可变的,编译器一开始就能确定要调用的版本,这叫做静态绑定,这些方法在类加载的时候就会把符号引用转化为该方法的直接引用。与之对应,在程序运行期间确定方法调用版本的调用方式叫做动态绑定,此时,虚拟机会为每个类创建一个方法表,列出所有方法签名和实际调用的方法,这样一来虚拟机在调用方法时,只用查找该表就行了,只有在调用时采用动态绑定的方法才能体现出多态特性。
 

猜你喜欢

转载自blog.csdn.net/lanlangtu/article/details/87858714