慎用重载_1

对象的运行时类型并不影响“哪个重载版本将被执行”;选择工作是在编译时候进行的,完全基于参数的编译时类型。

看个例子先:

package com.wjy.multithread;

public class MainTest {
    
    public static void show(int a){
        System.out.println("Integer");
    }
    
    public static void show(double a){
        System.out.println("Double");
    }
    
    public static void show(Object a){
        System.out.println("Object");
    }
    public static void main(String args[]){
        Object arr[]={2,22,2.5};
        for(Object object : arr){
            show(object);
        }
    }
}

大家猜猜结果,可能认为首先会输出Integer,但实际上结果是:

Object
Object
Object

对,你没看错,输出了三遍Object.神马情况? 你可能认为show方法会自动识别元素类型,调用合适的重载方法。但实际上却不是,编译的时候决定的类型会发挥作用,无论运行时是什么类型都无所谓,编译时已经定了。无语吧。方法的重载机制是不完美的。他并没有提供这一功能。

 

//*********************************************************************************************************************

 

但是来看看类之间的覆盖例子:

package com.wjy.multithread;

public class GrandFather {
    public void show(){
        System.out.println("GrandFather");
    }
}
package com.wjy.multithread;

public class Father extends GrandFather {
    @Override
    public void show(){
        System.out.println("Father");
    }
}
package com.wjy.multithread;

public class Son extends Father{
    @Override
    public void show(){
        System.out.println("Son");
    }
}

测试代码:

package com.wjy.multithread;

public class MainTest {
    public static void main(String args[]){
        GrandFather arr2[]={new GrandFather(),new Father(),new Son()};
        for(GrandFather grandFather : arr2){
            grandFather.show();
        }
    }
}

正如你所料,结果是:

GrandFather
Father
Son

这才是我们想要的答案,可见方法重载机制并没有覆盖机制的这些优势。所以,慎用重载。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值