Java의 일반 배열
Java에서는 제네릭과 배열이 직접적으로 공존하지 않습니다. 비교 가능한 유형을 확장하는 제네릭 배열을 만들려고 하면 오류가 발생할 수 있습니다. 이에 대한 근본적인 이유는 Java 제네릭이 컴파일 중에 지워지기 때문입니다.
다음 코드를 고려하십시오.
<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의 유형 삭제는 배열을 공변으로 취급합니다. 즉, 요소의 유형을 유지합니다. 런타임에. 따라서 일반 유형의 배열은 비교 가능한 유형의 배열과 동일한 유형이 아니며 후자를 전자로 변환할 수 없습니다.
이 문제를 피하려면 Array.newInstance를 사용하는 것이 좋습니다. ():
<code class="java">private Comparable[] hashtable; ... hashtable = (Comparable[])Array.newInstance(Comparable.class, tableSize);</code>
그러나 이 접근 방식에는 한계가 있습니다. 레거시 코드, 외부 라이브러리 또는 다른 언어와의 상호 운용성을 위해서는 진정한 제네릭 배열이 필요할 수 있습니다.
궁극적으로 Java에서는 제네릭이 포함된 배열을 사용하지 않는 것이 일반적으로 권장됩니다. 대신 더 많은 유연성과 유형 안전성을 제공하는 ArrayList 또는 HashMap과 같은 컬렉션 클래스 활용을 고려해 보세요.
위 내용은 Java에서 제네릭 배열을 만들 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!