我有两种方法如下
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
答案 0 :(得分:16)
Java Generics是一种仅限编译时的语言功能;在编译期间,泛型类型(例如String
和Integer
)擦除,字节码只包含原始类型,如下所示:
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;。