方法重载指同一类中多个同名方法参数列表不同,编译期根据参数数量、类型或顺序精确匹配,仅参数列表决定重载,与返回值、修饰符、异常声明无关。

Java里的方法重载,是指在同一个类中定义多个同名方法,但它们的参数列表必须不同——也就是参数的数量、类型或顺序至少有一项不一致。编译器在调用时,会根据你传入的实际参数自动选择最匹配的那个方法,这个过程发生在编译期,不依赖对象实例,也不看返回值或修饰符。
参数列表是唯一判断依据
方法是否构成重载,只看方法名 + 参数列表(类型、个数、顺序),其他全部无关:
- 返回值类型不同 ≠ 重载(编译报错)
- static 和非 static 同名同参 ≠ 重载(编译报错,因为 static 不属于方法签名)
- public/private 修饰符不同 ≠ 重载(不影响重载判定)
- throws 异常声明不同 ≠ 重载(可任意搭配)
三种典型的参数差异方式
只要参数列表不同,就满足重载条件。常见组合有:
-
参数个数不同:比如
add(int)和add(int, int) -
参数类型不同:比如
print(String)和print(int) -
参数顺序不同(仅当类型组合不同时有效):比如
process(String, int)和process(int, String)
静态与非静态方法可以共存重载
只要签名不同,静态方法和实例方法完全可以同名共存:
立即学习“Java免费学习笔记(深入)”;
- ✅ 合法:
void show(String s)(实例方法)和static void show(int n)(静态方法) - ❌ 非法:
void show()和static void show()(签名完全相同,编译失败) - 调用时也明确区分:实例方法靠对象调用,静态方法靠类名调用
编译器匹配有严格优先级
当你传入参数调用重载方法时,Java不会随便选一个,而是按以下顺序精确匹配:
- 先找完全匹配(类型一字不差)
- 再找自动类型提升(如
byte→int) - 接着考虑装箱/拆箱(如
int↔Integer) - 最后才 fallback 到varargs(可变参数)
- 如果两个方法同样“合适”,编译器直接报错:“ambiguous method call”










