从一道测试题分析java中的方法重载(overload)

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

http://blog.csdn.net/mingjava/archive/2004/06/23/24159.aspx

本文旨在通过一道测试题目分析java语言中方法重载的机制,帮助读者更好的掌握java语言的基础知识。

首先我们先看一道测试题目,源代码如下所示,你觉得程序能否通过编译呢,如果可以通过编译输出的结果会是什么呢?

//TestOverLoad.java

public class TestOverLoad

{

public static void main(String[] args)

{

Test test = new Test();

test.print(null);

}

}

class Test

{

public void print(String some)

{

System.out.println("String version print");

}

public void print(Object some)

{

System.out.println("Object version print");

}

}

答案是可以通过编译,输出的结果是String version print。不知道你猜测的是否准确是否知道其中的原理,这个题目明显是考察方法重载的,重载使得java的类可以有具有多个相同方法名的方法。编译器可以通过方法的参数的类型和个数来区分他们。而返回值和异常是不能作为区别标志的。上面的程序输出了String version print是遵循了方法重载中准确性的原则,null是作为一个很特别的参数传给了方法print(),因为你可以认为null是String,也可以认为null是Object。但是从层次上看Object处在更上层,String是从Object继承过来的,调用print(String some)将更准确。

如果在TestOverLoad类中再添加一个方法如下所示,这样会如何呢?

public class TestOverLoad

{

public static void main(String[] args)

{

Test test = new Test();

test.print(null);

}

}

class Test

{

public void print(String some)

{

System.out.println("String version print");

}

public void print(Object some)

{

System.out.println("Object version print");

}

public void print(StringBuffer some)

{

System.out.println("StringBuffer version print");

}

}

答案是不能通过编译,为什么呢?由于StringBuffer和String并没有继承上的关系,因此编译器感觉StringBuffer和String作为参数的方法都很准确,它就不知道到时候会运行哪个方法了,因此会出现编译错误,这是方法重载中唯一性的原则。如果我们把参数null修改为"hello world",那么就可以通过编译并运行输出String version print了。

曾经在java.sun.com上读文章看到一篇文章说方法的返回值也是区别方法的标志,其实这是错误的。看看下面的程序

public class A

{

public int aMethod(String s)

{

System.out.println(s);

return 1;

}

public void aMethod(String s)

{

System.out.println(s);

}

}

编译的时候会提示aMethod(String s)方法已经定义过的错误。实践证明一切!

没有其他编成滴基础,对于好些概念都不知道..什么封装,继承,多态,重载,重构........都很模糊,幸好有网络..

GOOGLE以下就有好多答案..

上面这个偶差不多了解了什么叫重载列....而且好象是优先考虑子类型的参数....

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航