다음 코드 조각을 고려하세요.
ArrayList<String> a = new ArrayList<String>(); String[] s = a.toArray(new String[0]);
이 코드는 Java 6과 7 모두에서 성공적으로 컴파일됩니다. 그러나 List 참조가 원시 유형으로 선언되면
ArrayList a = new ArrayList(); String[] s = a.toArray(new String[0]);
String[]이 필요하지만 Object[]가 발견되었다는 컴파일러 오류가 발생합니다. toArray 메소드 서명이
<T> T[] toArray(T[] a);
인 경우 이 동작은 예상치 못한 것입니다. 이는 메소드가 매개변수화되어 있고 해당 유형 매개변수가 목록의 유형 매개변수와 관련이 없음을 나타냅니다.
이해하려면 이 코드가 컴파일되지 않는 이유는 인스턴스 참조에 원시 유형을 사용하면 모든 인스턴스 멤버에 대해 제네릭을 사용하는 기능이 무효화된다는 점에 유의하는 것이 중요합니다. 이 동작은 다음 스니펫에 설명된 대로 일반 메서드로 제한되지 않습니다.
public class MyContainer<T> { public List<String> strings() { return Arrays.asList("a", "b"); } } MyContainer container = new MyContainer<Integer>(); List<String> strings = container.strings(); // This line will produce an unchecked warning!
이 제한은 Java 언어 사양(4.8)에 지정되어 있습니다.
"생성자의 유형 슈퍼클래스나 슈퍼인터페이스에서 상속되지 않은 원시 유형 C의 인스턴스 메서드 또는 비정적 필드 M은 C에 해당하는 일반 선언에서 해당 유형이 삭제된 원시 유형입니다."
위 내용은 목록 참조에 원시 유형을 사용하면 일반 메소드 사용이 방지되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!