重载问题

  1. public class ExamTest {  
  2.     public void myMethod(Object o) {  
  3.         System.out.println(”my object”);  
  4.     }  
  5.   
  6.     public void myMethod(String str) {  
  7.         System.out.println(”my string”);  
  8.     }  
  9.   
  10.     @Test  
  11.     public void test1() {  
  12.         this.myMethod(null);  
  13.     }  
  14. }  
public class ExamTest {
    public void myMethod(Object o) {
        System.out.println("my object");
    }

    public void myMethod(String str) {
        System.out.println("my string");
    }

    @Test
    public void test1() {
        this.myMethod(null);
    }
}

打印结果是?myMethod()方法有重载,那么到底是调用哪个方法呢?

经实测,打印的结果是my string。这是因为null从子类开始匹配,String类是Object类的子类,所以匹配的是参数类型是String类型的方法。假如本类中没有参数类型是String类型的方法,则会直接匹配myMethod(Object o)方法。

  1. public class ExamTest {  
  2.     public void myMethod(Object o) {  
  3.         System.out.println(”my object”);  
  4.     }  
  5.   
  6.     @Test  
  7.     public void test1() {  
  8.         this.myMethod(null);  
  9.     }  
  10. }  
public class ExamTest {
    public void myMethod(Object o) {
        System.out.println("my object");
    }

    @Test
    public void test1() {
        this.myMethod(null);
    }
}
会打印出my object。

又假如有多个参数类型是Object类的子类的类型的方法,则编译器不知道要匹配哪个方法,会报编译错误。如下

  1. public class ExamTest {  
  2.     public void myMethod(Object o) {  
  3.         System.out.println(”my object”);  
  4.     }  
  5.   
  6.     public void myMethod(String str) {  
  7.         System.out.println(”my string”);  
  8.     }  
  9.   
  10.     public void myMethod(Date date) {  
  11.         System.out.println(”my date”);  
  12.     }  
  13.   
  14.     @Test  
  15.     public void test1() {  
  16.         this.myMethod(null);  
  17.     }  
  18. }  
public class ExamTest {
    public void myMethod(Object o) {
        System.out.println("my object");
    }

    public void myMethod(String str) {
        System.out.println("my string");
    }

    public void myMethod(Date date) {
        System.out.println("my date");
    }

    @Test
    public void test1() {
        this.myMethod(null);
    }
}

为了证明上面的结论,又写了下面代码:

  1. public class ExamTest {  
  2.     public void myMethod(Object o) {  
  3.         System.out.println(”my object”);  
  4.     }  
  5.   
  6.     public void myMethod(TestClass testClass) {  
  7.         System.out.println(”my testClass”);  
  8.     }  
  9.   
  10.     public void myMethod(TestClass2 testClass) {  
  11.         System.out.println(”my testClass2”);  
  12.     }  
  13.   
  14.     @Test  
  15.     public void test1() {  
  16.         this.myMethod(null);  
  17.     }  
  18. }  
  19.   
  20. class TestClass {  
  21.   
  22. }  
  23.   
  24. class TestClass2 extends TestClass {  
  25.   
  26. }  
public class ExamTest {
    public void myMethod(Object o) {
        System.out.println("my object");
    }

    public void myMethod(TestClass testClass) {
        System.out.println("my testClass");
    }

    public void myMethod(TestClass2 testClass) {
        System.out.println("my testClass2");
    }

    @Test
    public void test1() {
        this.myMethod(null);
    }
}

class TestClass {

}

class TestClass2 extends TestClass {

}

上面代码中,继承关系是TestClass2继承TestClass,而TestClass又继承Object。所以将会调用myMethod(TestClass2 TestClass)方法,打印出来的是my testClass2。

                </div>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值