Dlaczego kolekcje niezwiązane z klasą szablonów upuszczają swój typ? Oto przykład: (Niestety, nie będzie kompilować z powodu błędu jestem zagubiony.)Ogólna liczba niepowiązanych kolekcji
package test;
import java.util.ArrayList;
import java.util.List;
public class TemplateTest {
public static class A { }
public static class B<T extends Comparable> {
List<A> aList = new ArrayList<A>();
public List<A> getAList() {
return aList;
}
public int compare(T t, T t1) {
return t.compareTo(t1);
}
}
public static void main(String[] args) {
B b = new B();
for (A a : b.getAList()) { //THIS DOES NOT WORK
}
List<A> aList = b.getAList(); //THIS WORKS
for (A a : aList) {
}
}
}
Ten kod generuje błąd przy kompilacji:
test/TemplateTest.java:24: incompatible types
found : java.lang.Object
required: test.TemplateTest.A
for (A a : b.getAList()) {
Gdybym określić szablon z B
, takich jak B<String>
, lub jeśli całkowicie usunę szablon z B, wszystko jest w porządku.
Co się dzieje?
EDIT: ludzie wskazał, nie było potrzeby, aby B generic więc dodałem do B
Przepraszam za nonsens przed ... Wydaje się to do być związane z błędem. Sława! –
Nie jest to ściśle związane z pytaniem, ale * nie * określenie parametru typu w Javie jest ogólnie uważane za błąd programowania. Użycie typu surowego kompiluje się tylko jako ustępstwo dla wstecznej zgodności. – Affe
Również nazywam błąd kompilatora. Wygląda na to, że rodzaj wyrażenia po prawej stronie, zastosowanego w ulepszonej pętli for, jest określany w sposób szczególny (co nie jest zaskakujące, ponieważ wymaga specjalnych tablic), a to się psuje, gdy chodzi o typ surowy. (Tzn. Widząc gdzieś surowego typu, zakłada, że całe wyrażenie ma usunięte typy). – millimoose