为什么这不是超载?

时间:2013-12-02 06:28:18

标签: java generics overloading

我有两种方法如下

public void add(List<String> strs) {...}

public void add(List<Integer> ints) {...}

我遇到编译错误,所以我的问题是为什么这不会重载,那么使用泛型的优势是什么?

这是我得到的错误:

Method add(List<Integer>) has the same erasure add(List<E>) as another method in type Child

5 个答案:

答案 0 :(得分:16)

Java Generics是一种仅限编译时的语言功能;在编译期间,泛型类型(例如StringInteger擦除,字节码只包含原始类型,如下所示:

public void add(List strs) {...}

因此,您不能拥有多个方法,这些方法的签名仅在通用类型中有所不同。有几种方法可以解决这个问题,包括varargs和使你的方法本身通用,最好的方法取决于具体的任务。

泛型的优势在于,在一个采用List<String>的方法中,您可以添加或删除List中的元素,并将它们视为String个对象,而无需添加到处都是明确的铸造。

答案 1 :(得分:4)

通用类型在运行时被擦除。因此,public void add(List<String> strs)public void add(List<Integer> ints){...........}是相同的类型,编译器只会对您可以对它们执行的操作设置编译时限制。

答案 2 :(得分:2)

当您针对泛型类型或方法编译某些代码时,编译器会计算出您的真正含义(即T的类型参数是什么)并在编译时验证您正在做正确的事情,但是代码再次只是用j ava.lang.Object来讨论 - 编译器会在必要时生成额外的强制转换。在执行时,List<Integer>List<String>完全相同;额外的类型信息已被编译器删除。

因此会出现编译错误。

答案 3 :(得分:0)

Java中,您可以执行此操作(重载),如下所示,参数列表包含List

 public void add(List strs){

 }

如果使用具有相同方法名称的不同类型的List,它将被视为相同的方法。

答案 4 :(得分:0)

请记住,JVM不会决定在运行时调用哪个方法。与虚拟方法/方法相反,重写方法的重写在编译时完成。 method overloading上的Java教程甚至指出&#34;应该谨慎使用重载方法......&#34;。