我写了这段测试代码
public class ConstructorTestApplication {
private static String result;
public static void main(String[] args) {
ConstructorTest test1 = new ConstructorTest(0);
System.out.println(result);
}
private static class ConstructorTest {
public ConstructorTest(double param){
result = "double constructor called!";
}
public ConstructorTest(float param) {
result = "float constructor called!";
}
}
}
结果是
float constructor called!
为什么调用 float 构造函数而不是 double 构造函数?这是动态方法查找的一部分吗?
最佳答案
ConstructorTest(float param)
是两个构造函数中最具体的方法,因为带有 double
参数的方法可以接受任何 float
值,但反之则不然。
15.12.2.5. Choosing the Most Specific Method
If more than one member method is both accessible and applicable to a method invocation, it is necessary to choose one to provide the descriptor for the run-time method dispatch. The Java programming language uses the rule that the most specific method is chosen.
The informal intuition is that one method is more specific than another if any invocation handled by the first method could be passed on to the other one without a compile-time type error.
关于java - 为什么在调用构造函数时将 int 隐式转换为 float 而不是 double?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28655610/