public void info(String s,double b){
System.out.println(s+" double----"+b);
}
public static void main(String[] args) {
new TestOverload().info("hello world", 6);
}
我们可以看到如上程序,当只有double时我们输入的6,输出结果是
hello world------6.0 -------------------------->这是因为java的自动向上转型造成的,这个基本都没什么问题
那么我们出现了下面的这样的情况:
public void info(String s,double b){此时我们会看到输出结果是
System.out.println(s+" double----"+b);
}
public void info(String s,int a){
System.out.println(s+" int------"+a);
}
public static void main(String[] args) {
new TestOverload().info("hello world", 6);
}
hello wolrd --- ---6 --------------------->这是因为java虚拟机的精确匹配原则,使得调用第二个重载的方法,
这个也基本没什么问题
那么下面:
public void info(Object obj,double b){这样输出结果是null objs---------6.0
System.out.println(obj+" obj-------"+b);
}
public void info(Object[]objs,double b){
System.out.println(objs+" objs-----"+b);
}
这样就出现了一个问题,为什么会是调用第二个重载的方法呢
其实此时java虚拟机将object[] 看成了object的子类 所以这样就很好解释这样的结果了
最后还有一个问题:
public void info(Object obj,int b){
System.out.println(obj+" obj-------"+b);
}
public void info(Object[]objs,double b){
System.out.println(objs+" objs-----"+b);
}
public static void main(String[] args) {
new TestOverload().info(null, 6);
}
我把第一个形参改成 int类型时会报错,
还是一样,像之前说得一样 ,java虚拟机的精确匹配原则
此时第一个参数匹配object[] 第二参数匹配int类型,此时编译器是精确匹配的所以java编译器就会报错
参考-----《疯狂java》