Java では、生の型を使用すると、ジェネリック メソッドと対話するときに予期しない結果が生じる可能性があります。
次のコード スニペットを考えてみましょう:
ArrayList<String> a = new ArrayList<String>(); String[] s = a.toArray(new String[0]);
このコードは、JDK 1.6 と JDK 1.7 の両方で正常にコンパイルされます。ただし、List 参照を raw 型として宣言すると、
ArrayList a = new ArrayList(); String[] s = a.toArray(new String[0]);
String[] が必要だが Object[] が見つかったことを示すコンパイラ エラーが発生します。
これこの動作は、List 参照に生の型を使用すると、その型のインスタンス メンバーに対してジェネリックを使用する機能が削除されるという事実から生じます。次の例に示すように、これはジェネリック メソッドに限定されません。
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!
この動作は Java 言語仕様 (JLS) で明示的に規定されています。
コンストラクターの型 (§ 8.8)、インスタンス メソッド (§8.4、§9.4)、または非静的フィールド (§8.3) スーパークラスまたはスーパーインターフェイスから継承されていない生の型 C の M は、その型の消去に対応する生の型です。 C に対応するジェネリック宣言。
したがって、ジェネリック メソッドを使用したりインスタンス メンバーにアクセスしたりするときに、予期しない制限やコンパイル時エラーが発生する可能性があるため、生の型の使用は注意して行う必要があります。
以上がJava でジェネリック メソッドを操作するときに、Raw 型が問題を引き起こすのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。