Generische Arrays in Java
In Java existieren Generika und Arrays nicht direkt nebeneinander. Beim Versuch, ein Array von Generika zu erstellen, das einen vergleichbaren Typ erweitert, kann ein Fehler auftreten. Der Hauptgrund dafür ist, dass Java-Generika während der Kompilierung gelöscht werden.
Betrachten Sie den folgenden Code:
<code class="java">public class Hash<T extends Comparable<String>> { private T[] hashTable; private int tableSize; Hash(int records, double load) { tableSize = (int)(records / loadFactor); tableSize = findNextPrime(tableSize); hashTable = (T[])(new Object[tableSize]); // Error: Object cannot be cast to Comparable } }</code>
Java's Typlöschung behandelt Arrays als kovariante, was bedeutet, dass sie den Typ ihrer Elemente beibehalten zur Laufzeit. Daher ist ein Array eines generischen Typs nicht derselbe Typ wie ein Array seines vergleichbaren Typs, und letzterer kann nicht in ersteren umgewandelt werden.
Um dieses Problem zu umgehen, besteht eine Problemumgehung darin, Array.newInstance zu verwenden ():
<code class="java">private Comparable[] hashtable; ... hashtable = (Comparable[])Array.newInstance(Comparable.class, tableSize);</code>
Dieser Ansatz weist jedoch Einschränkungen auf. Legacy-Code, externe Bibliotheken oder die Interoperabilität mit anderen Sprachen erfordern möglicherweise echte generische Arrays.
Letztendlich wird generell empfohlen, die Verwendung von Arrays mit Generika in Java zu vermeiden. Erwägen Sie stattdessen die Verwendung von Sammlungsklassen wie ArrayList oder HashMap, die mehr Flexibilität und Typsicherheit bieten.
Das obige ist der detaillierte Inhalt vonWarum kann ich in Java kein Array von Generika erstellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!