方法重写实现多态,子类重写父类方法需遵循方法名、参数列表一致,返回类型兼容,访问修饰符不更严格,不可重写private、static、final方法,建议使用@Override注解。

在Java中,方法重写(Override)是实现多态的核心机制。通过子类对父类中的方法进行重新定义,可以在运行时根据对象的实际类型调用对应的方法,从而实现“同一操作,不同行为”的多态特性。
方法重写的基本规则
要正确实现方法重写,必须遵守以下规则:
- 方法名、参数列表必须与父类中被重写的方法完全一致
- 返回类型可以相同,或是其子类型(协变返回)
- 访问修饰符不能比父类方法更严格(例如父类是protected,子类不能是private)
- 不能重写父类的private、static或final方法
- 建议使用@Override注解,帮助编译器检查是否真正实现了重写
通过继承实现多态
多态意味着同一个引用类型可以指向不同的实际对象,并在调用方法时表现出不同的行为。这依赖于方法重写和动态绑定(运行时绑定)。
示例代码:
立即学习“Java免费学习笔记(深入)”;
class Animal {
void makeSound() {
System.out.println("Animal makes a sound");
}
}
class Dog extends Animal {
@Override
void makeSound() {
System.out.println("Woof!");
}
}
class Cat extends Animal {
@Override
void makeSound() {
System.out.println("Meow!");
}
}
测试多态行为:
public class TestPolymorphism {
public static void main(String[] args) {
Animal a1 = new Dog();
Animal a2 = new Cat();
a1.makeSound(); // 输出: Woof!
a2.makeSound(); // 输出: Meow!
}
}
尽管a1和a2的引用类型都是Animal,但实际调用的是各自子类重写后的方法,这就是多态的体现。
应用场景与最佳实践
方法重写结合多态广泛应用于框架设计、接口扩展和业务逻辑解耦中。
- 在定义通用处理逻辑时,使用父类类型作为参数,接受各种子类对象
- 利用集合存储不同子类对象,统一调用重写方法进行处理
- 避免在构造函数中调用可被重写的方法,防止子类状态未初始化导致问题
- 重写equals、hashCode、toString等Object类方法时,确保符合语义一致性
基本上就这些。掌握方法重写和多态,是理解Java面向对象编程的关键一步。只要遵循语法规范,合理设计类结构,就能写出灵活、可扩展的代码。










