【发布时间】:2018-09-26 12:48:50
【问题描述】:
我正在尝试创建一个名为“OrderedList”的泛型类,它使用泛型类型的数组来存储使用类型预定义排序的特定类型。我在看似简单的操作时遇到了麻烦,我不明白为什么。这是我的代码。
public OrderedList() {
list = (T[]) new Object[100];
size = 0;
}
public <T extends Comparable<T>> void add(T o) {
if (size == list.length) resize();
list[size] = o;
for (int i = 0; i < size; i++) {
o.compareTo((T) list[i]);
}
size++;
}
private void resize() {
int newSize = (int) (1.5 * (double) list.length);
T[] newArray = (T[]) new Object[newSize];
for (int i = 0; i < size; i++) {
newArray[i] = list[i];
}
list = newArray;
}
我得到的错误是 add 方法中的第二行,“list[size] = o”。它向我提供了一个错误,上面写着“不兼容的类型。必需:T。找到:T。”此外,每当我对<T extends Comparable<T>> 进行实例化时,该错误就会消失,但是我无法比较我试图在通用数组中排序的两个对象。
谁能帮帮我?我真的很困惑。任何帮助表示赞赏。
【问题讨论】:
标签: java generics compare generic-programming