方法重写与之前的方法重载不同
回顾一下方法重载,相同的方法名不同参数类型和参数数量以及参数顺序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package Demo1; import java.util.Arrays; public class Demo011 { public static void main(String[] args) { Demo011 D11= new Demo011(); D11.demo( 12 , 232 , 43 , 3 ); //4个实际参数,则调用第三个demo方法 } public void demo( int a, int b){ System.out.println(a+b); } public void demo( int a, int b, int c){ System.out.println(a+b+c); } public void demo( int ...ints){ System.out.println(Arrays.toString(ints)); } } |
方法重写
重写都是方法的重写与属性无关
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
package Demo1; public class Demo012 { public static void main(String[] args) { B b = new B(); b.demo(); } } class A{ public static void demo(){ System.out.println( "Ademo" ); } } class B extends A{ public static void demo(){ System.out.println( "Bdemo" ); } } |
执行结果:
Bdemo
父类的引用指向子类进行引用
1
2
3
4
5
6
7
8
|
public static void main(String[] args) { //方法的调用只和数据类型有关 B b = new B(); //调用的是B类的静态方法 b.demo(); //父类的引用指向子类 A a = new A(); //调用的是A类的静态方法 a.demo(); } |
执行结果:
Bdemo
Ademo
使用快捷键Alt+insert快速生成重写方法
Override重写方法
1
2
3
4
5
6
7
8
9
10
11
|
class A{ public void demo(){ System.out.println( "Ademo" ); } } class B extends A{ @Override //注解,有功能的注释 public void demo() { super .demo(); //默认调用父类的demo()方法 } } |
使用Override重写默认是调用父类的方法,我们可以在重写方法中调用自己的方法
1
2
3
4
5
6
7
8
9
10
11
12
|
class A{ public void demo(){ System.out.println( "Ademo" ); } } class B extends A{ @Override public void demo() { //super.demo(); 默认调用父类的demo()方法输出Ademo System.out.println( "Bdemo" ); } } |
重写之后执行结果:
Bdemo
Bdemo
子类重写父类的demo()方法之后输出为demoB,但是并不是子类重写之后将父类的方法修改了,子类在进行调用的时候调用的是重写后父类的方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
package Demo3; public class demo005 { public static void main(String[] args) { DemoB DB = new DemoB(); DB.demo(); //调用子类的demo DemoA DA= new DemoA(); //调用父类的demo DA.demo(); } } class DemoA{ public void demo(){ System.out.println( "demoA" ); } } class DemoB extends DemoA{ //继承 @Override public void demo(){ System.out.println( "demoB" ); } } |
执行结果:
demoB
demoA
但是我可以完全不继承父类也能输出demoB,demoA
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
package Demo3; public class demo005 { public static void main(String[] args) { DemoB DB = new DemoB(); DB.demo(); DemoA DA= new DemoA(); DA.demo(); } } class DemoA{ public void demo(){ System.out.println( "demoA" ); } } class DemoB{ //A与B没有继承关系 public void demo(){ System.out.println( "demoB" ); } } |
执行结果:
demoB
demoA
两种方式有什么区别呢?
- 子类继承父类重写方法,是通过子类调用父类的方法进行重写的,子类执行结果也是重写后的方法,但并不是子类把父类的方法修改了
- 方式二是在两个不同类下创建demo()方法,通过对象进行调用。
父类方法若添加static修饰符则重写失败提示错误
进行方法重写时静态方法和非静态方法的区别很大,如果是加了static静态方法,调用结果之和左边定义的类有关。方法重写与非静态方法有关
私有方法无法进行方法重写,重写的关键词只能是public不能是private私有的
重写小结:
- 方法重写需要有继承关系,子类重写父类的方法
- 子类方法与父类的方法方法名和修饰符必须相同
- 以及方法的参数列表必须相同,不相同则为方法重载
- 修饰符范围可以扩大但是不能缩小,private(小)–>proteated–>default–>public(大)
- 重写可能会抛出异常,异常范围可以被缩小但不能扩大
为什么需要重写?
- 父类的功能子类不一定需要或者不一定满足,父类的东西太多了子类可能只需要一点
快捷键Alt+insert
快速创建Override
总结
本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注服务器之家的更多内容!
原文链接:https://blog.csdn.net/xuzhibin666/article/details/119487908