Di Jawa, menggunakan jenis mentah boleh membawa kepada akibat yang tidak dijangka apabila berinteraksi dengan kaedah generik.
Pertimbangkan coretan kod berikut:
ArrayList<String> a = new ArrayList<String>(); String[] s = a.toArray(new String[0]);
Kod ini berjaya disusun dalam kedua-dua JDK 1.6 dan JDK 1.7. Walau bagaimanapun, jika kami mengisytiharkan rujukan Senarai sebagai jenis mentah:
ArrayList a = new ArrayList(); String[] s = a.toArray(new String[0]);
Kami menghadapi ralat pengkompil yang menunjukkan bahawa String[] diperlukan tetapi Objek[] ditemui.
Ini tingkah laku berpunca daripada fakta bahawa menggunakan jenis mentah untuk rujukan Senarai mengalih keluar keupayaan untuk menggunakan generik contohnya ahli jenis itu. Ini tidak terhad kepada kaedah generik, seperti yang ditunjukkan oleh contoh berikut:
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!
Tingkah laku ini dinyatakan secara eksplisit dalam Spesifikasi Bahasa Java (JLS):
Jenis pembina (§ 8.8), kaedah instance (§8.4, §9.4), atau medan bukan statik (§8.3) M daripada jenis mentah C yang tidak diwarisi daripada superclass atau superinterfacenya ialah jenis mentah yang sepadan dengan pemadaman jenisnya dalam pengisytiharan generik yang sepadan dengan C.
Oleh itu, menggunakan jenis mentah harus dilakukan dengan berhati-hati, kerana ia boleh membawa kepada pengehadan yang tidak dijangka dan juga ralat masa penyusunan apabila menggunakan kaedah generik atau mengakses ahli contoh.
Atas ialah kandungan terperinci Mengapa Jenis Mentah Menyebabkan Masalah Apabila Bekerja dengan Kaedah Generik di Jawa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!