方法重载发生在同类中,参数列表不同即可,用于提供多种调用方式;方法重写发生在子类对父类方法的覆盖,需签名一致,实现多态。

在Java中,方法重载(Overloading)和方法重写(Overriding)是面向对象编程的两个核心概念,它们都涉及方法名称的重复使用,但应用场景和规则完全不同。理解并正确使用这两个机制,有助于提升代码的可读性、可维护性和扩展性。
方法重载:同一个类中方法名相同但参数不同
方法重载发生在同一个类中,多个方法具有相同的名称,但参数列表不同(参数类型、数量或顺序不同)。返回类型可以不同,但不能仅靠返回类型来区分重载方法。
常见用途包括提供多种方式调用同一个功能,比如不同的输入类型或可选参数。
示例:定义一个计算面积的方法,支持矩形和正方形:
立即学习“Java免费学习笔记(深入)”;
public class Calculator {
public int area(int side) {
return side * side;
}
public int area(int length, int width) {
return length * width;
}
public double area(double radius) {
return Math.PI * radius * radius;
}
}
上述代码中,area 方法被重载了三次,分别处理正方形、矩形和圆形的面积计算。调用时根据传入参数自动匹配对应方法。
注意点:
- 参数列表必须不同,否则编译报错。
- 访问修饰符可以不同。
- 返回类型不影响重载判断。
- 静态方法也可以重载。
方法重写:子类重新定义父类方法
方法重写发生在继承关系中,子类提供父类中某个方法的具体实现。重写要求方法名、参数列表、返回类型完全一致(协变返回类型除外),且访问权限不能更严格。
它是实现多态的关键机制,允许运行时动态绑定具体方法。
示例:
class Animal {
public void makeSound() {
System.out.println("Animal makes a sound");
}
}
class Dog extends Animal {
@Override
public void makeSound() {
System.out.println("Dog barks");
}
}
当调用 makeSound() 时,如果对象是 Dog 类型,就会执行 Dog 的实现,体现多态行为。
关键规则:
- 只能重写继承来的方法(非private、非static、非final)。
- 必须使用 @Override 注解,提高代码可读性和安全性。
- 子类方法的访问修饰符不能比父类更严格(如父类是 protected,子类不能用 private)。
- 抛出的异常不能比父类更宽泛。
重载与重写的区别总结
理解两者的差异对避免错误至关重要:
- 发生位置:重载在同类中,重写在父子类之间。
- 参数要求:重载要求参数不同,重写要求参数完全相同。
- 多态支持:重写支持运行时多态,重载是编译时决定。
- 注解使用:@Override 只用于重写,加在重载方法上会导致编译错误。
实际开发中的使用建议
在项目实践中,合理运用重载和重写能提升设计质量:
- 用重载简化API,让用户以不同方式调用同一逻辑,比如构造函数重载很常见。
- 在框架设计中,通过重写模板方法实现扩展点,符合开闭原则。
- 避免过度重载导致调用歧义,尤其是自动类型转换可能引发意外匹配。
- 重写时不要改变方法的原始契约,确保行为一致性。
基本上就这些。掌握好重载和重写的规则与场景,能让Java代码更灵活、更规范。










