java 方法泛型入参T和String的重载关系详解
作者:赫双炏
这篇文章主要介绍了java 方法泛型入参T和String的重载关系详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
方法泛型入参T和String的重载关系
重载的基本知识不在这里讨论了
重载的一个关键理论,如果方法名相同,参数个数、父类型、位置也相同,则调用更加特殊化一个方法。
多余的没写,大家可以运行一下下面的代码,然后理解一下就ok了。
public class TestMain { public static void main(String[] args) { TestMain t = new TestMain(); t.func("message"); t.func(new String("message")); t.func(new Object()); } protected <T> void func(T data) { System.out.println("fun1" + data); } protected void func(String data) { System.out.println("fun2" + data); } }
由于string和T相比较,带有String data入参的方法更加特殊化,所以当传入String参数的时候,会调用第2个func。
网上还有关于null入参的讨论,我理解是由于null入参两个方法都可以,所以会选择更加特殊化的方法,也就是第二个func。
这里可以试一下,定义一个Object入参的方法,编译器会直接说与T data入参的方法歧义。
(T是一个泛型,没有具体说明类型,这里类似于Object类型)
重载遇到泛型的问题
今天被问到一个有意思的问题,大家都知道重载的概念吧:一个类中定义同名的方法,参数表不同(参数类型,或者参数个数不通);
但是,如果是下面这个两个方法呢
public static int fn(List<Integer> index) { return 1; } public static String fn(List<String> str) { return "str"; }
同名的两个方法,参数表中用到了集合,参数表里的泛型不一样,那么到底这样能不能编译通过呢?
反复求证,得出以下结论
使用Sun JDK的Javac来进行编译会通过,而其他编译器可能会拒绝编译这段代码
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。