目录

[转载]Java - 为什么不能根据返回类型来区分重载

什么是方法重载?为什么不能根据返回类型来区分重载?

方法的重载和重写都是实现多态的方式,区别在于前者实现的是编译时的多态性,而后者实现的是运行时的多态性。

重载发生在一个类中,同名的方法如果有不同的参数列表(参数类型不同、参数个数不同或者二者都不同)则视为重载。为什么这里不包括返回类型呢?很简单,如果只是返回类型不同,是无法区分开来的,如下:

1
2
float max(int a, int b);
int max(int a, int b);

在调用上述两个方法的时候,可以不用返回值,那么你怎么区分调用的是哪个方法?

在《深入理解Java虚拟机》中,6.3.6章节有这样一段:

在Java语言中,要重载一个方法,除了要与原方法具有相同的简单名称之外,还要求必须拥有一个与原方法不同的特征签名;

特征签名就是一个方法中各个参数在常量池中的字段符号引用的集合,也就是因为返回值不会包含在特征签名之中,因此Java语言里面是无法仅仅依靠返回值的不同来对一个已有方法进行重载。

但在Class文件格式之中,特征签名的范围更大一些,只要描述符不是完全一致的两个方法也可以共存。

也就是说,如果两个方法有相同的名称和特征签名,但返回值不同,那么也是可以合法存于同一个Class文件中的。

Class文件中同方法名、同参数、不同返回值可以,那为什么Java文件中不行呢?

因为Java语言规范的规定,所以编译时会出现错误。

那为什么Class文件可以呢?因为Java虚拟机规范和Java语言规范不同,两者是分开的。

如有更多兴趣,可以看看这篇文章:Java语言层面和JVM层面方法特征签名的区别 及 实例分析

转载链接