Java에서 원시 유형을 사용하면 일반 메소드와 상호작용할 때 예상치 못한 결과가 발생할 수 있습니다.
다음 코드 조각을 고려하십시오.
ArrayList<String> a = new ArrayList<String>(); String[] s = a.toArray(new String[0]);
이 코드는 JDK 1.6과 JDK 1.7 모두에서 성공적으로 컴파일됩니다. 그러나 List 참조를 원시 유형으로 선언하면:
ArrayList a = new ArrayList(); String[] s = a.toArray(new String[0]);
String[]이 필요하지만 Object[]가 발견되었음을 나타내는 컴파일러 오류가 발생합니다.
이것은 이러한 동작은 목록 참조에 원시 유형을 사용하면 해당 유형의 인스턴스 멤버에 대해 제네릭을 사용할 수 있는 기능이 제거된다는 사실에서 비롯됩니다. 이는 다음 예제에서 볼 수 있듯이 일반 메서드에만 국한되지 않습니다.
public class MyContainer<T> { public List<String> strings() { return Arrays.asList("a", "b"); } } MyContainer container = new MyContainer<Integer>(); List<String> strings = container.strings(); // gives an unchecked warning!
이 동작은 JLS(Java 언어 사양)에 명시적으로 명시되어 있습니다.
생성자의 유형(§ 8.8), 인스턴스 메서드(§8.4, §9.4) 또는 비정적 필드(§8.3) 슈퍼클래스나 슈퍼인터페이스에서 상속되지 않은 원시 유형 C의 M은 해당 유형의 삭제에 해당하는 원시 유형입니다. C에 해당하는 제네릭 선언.
따라서 원시 유형을 사용하는 경우 제네릭 메서드를 사용하거나 인스턴스 멤버에 액세스할 때 예상치 못한 제한이 발생할 수 있고 심지어 컴파일 시간 오류까지 발생할 수 있으므로 주의해야 합니다.
위 내용은 Java에서 일반 메소드로 작업할 때 원시 유형이 문제를 일으키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!