Ska*_*ani 3 java overloading primitive-types
我在做Java课程练习.我有这个包含重载方法的代码:
class A {
// Overloaded method
public void f(int n, float x) {
System.out.println("f(int n, float x) n = " + n + " x = " + x);
}
private void f(long q, double y) {
System.out.println("f(long q, double y) q = " + q + " y = " + y);
}
public void f(double y1, double y2) {
System.out.println("f(double y1, double y2) y1 = " + y1 + " y2 = " + y2);
}
public void g() {
int n = 1;
long q = 12;
float x = 1.5f;
double y = 2.5;
System.out.println("--- dans g ");
f(n, q);
f(q, n);
f(n, x);
f(n, y);
}
}
Run Code Online (Sandbox Code Playgroud)
主要:
public static void main(String[] args){
A a = new A() ;
a.g() ;
System.out.println ("--- dans main") ;
int n=1 ;
long q=12 ;
float x=1.5f ;
double y = 2.5 ;
a.f(n, q) ; // my problem is here
a.f(q, n) ;
a.f(n, x) ;
a.f(n, y) ;
}
Run Code Online (Sandbox Code Playgroud)
当我a.f(n,q)在main中调用该方法时,我期待一个错误,但是f(int n, float x)当我q是一个long数字并且它的大小比一个float大小(8字节/ 4字节)大时调用该方法所以我想知道这些原始类型是如何工作的?
方法调用占用规范的相当长的一部分.总而言之,编译器如下进行:
步骤2是这里最有趣的一个:这将在许多步骤中进行.总结一下:
您提供的参数与过载的任何参数类型都不完全匹配,因此您需要检查是否可以转换该参数以允许严格调用.严格调用中的转换是:
- 身份转换(§5.1.1)
- 扩展的原始转换(第5.1.2节)
- 扩大参考转换(第5.1.5节)
一个int可以通过标识转换被转换int.阿long可转化加宽原语转换到一个float.
因此f(int, float)适用.
f(long, double)并且f(double, double)也适用,因为int可以扩大到long和double; 并且long可以扩大到double.
然而,这些不是特定于f(int, float),因为int可以扩展到long和double,并且float可以扩展到double.因此,通过JLS Sec 15.12.2.5中规定的非正式直觉,这些方法的具体性不如f(int, float).因此,f(int, float)是被调用的那个.
| 归档时间: |
|
| 查看次数: |
134 次 |
| 最近记录: |