方法重载发生在同一类中,通过参数列表不同实现静态多态;方法重写发生在继承关系中,通过相同签名覆盖父类方法实现动态多态。

在Java中,方法重载(Overloading)和方法重写(Overriding)是面向对象编程中实现多态的两种重要机制。它们虽然名字相似,但应用场景、语法要求和运行机制完全不同。正确理解和使用这两者,有助于写出更清晰、可维护和扩展性强的代码。
方法重载:同一个类中方法名相同但参数不同
方法重载发生在同一个类中,多个方法拥有相同的名字,但参数列表不同(参数类型、个数或顺序不同)。返回类型可以不同,但不能仅靠返回类型区分重载方法。
关键点:
- 方法名必须相同
- 参数列表必须不同
- 访问修饰符可以不同
- 返回类型可以不同,但不能作为唯一区别
- 发生在编译期,属于静态多态
示例:
立即学习“Java免费学习笔记(深入)”;
public class Calculator {
public int add(int a, int b) {
return a + b;
}
public double add(double a, double b) {
return a + b;
}
public int add(int a, int b, int c) {
return a + b + c;
}
}
上述代码中,add 方法被重载了三次,编译器根据传入参数的不同自动选择调用哪个版本。
方法重写:子类重新定义父类的方法
方法重写发生在继承关系中,子类提供一个与父类中某个方法具有相同签名(方法名、参数列表)的方法,从而覆盖父类的行为。这是实现运行时多态的基础。
关键点:
- 必须有继承关系
- 方法名和参数列表必须完全一致
- 返回类型必须兼容(协变返回类型允许子类方法返回更具体的类型)
- 访问修饰符不能比父类更严格(例如父类是 protected,子类不能是 private)
- 不能重写父类的 private、static 或 final 方法
- 发生在运行期,属于动态多态
示例:
立即学习“Java免费学习笔记(深入)”;
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() 时,实际执行的是子类的方法:
Animal myPet = new Dog(); myPet.makeSound(); // 输出 "Dog barks"
重载与重写的常见误区与实践建议
在实际开发中,容易混淆两者的使用场景。以下是一些实用建议:
- 重载适合用于提供多种方式调用同一个逻辑,如构造函数重载、工具方法支持不同类型输入
- 重写用于定制继承行为,实现“同名方法,不同实现”
- 始终在重写方法上使用 @Override 注解,避免因拼写错误导致意外重载
- 注意重载方法的调用优先级:精确匹配 > 自动类型提升 > 自动装箱 > 可变参数
- 避免过度重载,否则会增加理解和维护成本
基本上就这些。掌握方法重载和重写的核心区别与使用场景,是写出高质量Java代码的基础。理解它们如何影响程序的静态绑定与动态分发,能帮助你更好地设计类结构和接口行为。不复杂但容易忽略细节,建议结合调试工具观察实际调用过程加深理解。










