作者热门文章
- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在使用返回通用列表的方法时遇到了一些问题。代码基本上是这样的:
public class MyClass{
private List<MyListElement> myList = new ArrayList<MyListElement>();
public <E> List<E> getGenericList(){
return new ArrayList<E>();
}
public void thisWorks(){
List<MyListElement> newList = getGenericList();
myList.addAll(newList);
}
public void thisDoesntWork(){
myList.addAll(getGenericList());
}
public void thisDoesntWorkEither(){
for(MyListElement elem : getGenericList()){
fiddle();
}
}
}
为什么 thisDoesntWork()
方法不起作用,还有其他解决方法吗(除了用 thisWorks()
方法,这种方法并不总是有效实用)?
最佳答案
编译器无法推断为类型参数选择什么类型 <E>
通用方法 getGenericList()
在thisDoesntWork()
.
在这种情况下,您需要通过调用 <MyListElement>getGenericList()
显式声明类型参数的类型
或者,您可以更改 getGenericList()
的签名接受Class<E>
争论。然后你会调用 getGenericList(MyListElement.class)
在两个thisWorks()
和 thisDoesntWork()
.不可否认,这有点冗长,但对于您的方法的客户来说绝对更直观。
我会说,作为一般规则,尝试使泛型方法的类型参数可以从该方法的参数中推断出来。
关于Java泛型列表返回类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13922370/
我是一名优秀的程序员,十分优秀!