方法重载发生在同一类中,仅由方法名和参数列表决定,与返回值等无关;方法重写发生在父子类间,要求方法名、参数、返回类型相同,是运行期动态绑定。
重载是编译期行为,只看**方法名和参数列表**,跟返回值类型、访问修饰符、异常声明完全无关。JVM 在编译时就根据调用处的实参类型和个数决定调用哪个重载版本。
static 方法可以重载,private 方法也可以(只是子类看不见)int 和 Integer 算不同(涉及自动装箱时需小心歧义)error: method xxx() is already defined in class YYY
void print(String s) 和 String print(String s) 当作重载,实际不合法重写是运行期行为,核心是「子类提供父类已有方法的新实现」,受 @Override 注解约束,编译器会校验签名是否真正匹配父类可访问方法。
private 或 protected(若父类是 public),但可以更宽松(如父类 protected,子类 public)Exception),但可以抛出更具体的异常(IOException)或不抛异常static 方法不能被重写(只能被隐藏),final 方法不能被重写,private 方法也不能被重写(它对子类不可见)很多问题不是语法写错,而是对「谁在调用」「绑定时机」理解偏差导致的意外行为。
Parent p = new Child(); p.show(new String()); // 调用 Parent 中参数为 String 的 show p.show(new Object()); // 若 Parent 有 show(Object),则调用它 —— 不是看 Child 有没有更匹配的重载

void m(T t) 和 void m(Object o) 在字节码层面可能冲突,导致编译失败,这种重载要格外谨慎看方法签名变化是否跨类、是否改了参数、是否加了 @Override 注解,再结合报错信息定位。
method does not override or implement a method from a supertype,说明你写了 @Override 但没真正匹配父类方法——大概率是参数类型写错(比如用了 int[] 而非 int...),或父类方法是 private/static
reference to xxx is ambiguous,说明重载选择不明确,比如传 null 给多个可接受引用类型的重载方法,需要显式强转