Rumah >Java >javaTutorial >Panduan Terbaik untuk Senarai di Java: Semua yang Anda Perlu Tahu
Tertib : Elemen mengekalkan susunan sisipannya.
Fleksibel : Membenarkan pendua, supaya anda boleh berulang-ulang seperti peringatan bos anda.
Paling Sesuai Untuk : Akses rawak pantas dan lelaran.
Kelemahan : Sisipan dan pemadaman perlahan (kerana elemen perlu beralih).
Kes Penggunaan : Apabila anda perlu mengakses elemen dengan kerap, seperti mengambil bingkai video dalam pemain media.
List<String> arrayList = new ArrayList<>(); arrayList.add("First"); arrayList.add("Second");
Reka Letak Memori : ArrayLists mengekalkan blok memori bersebelahan, diubah saiznya sebanyak 50% atau lebih apabila melebihi kapasitinya.b. Senarai Berpaut
Disokong Oleh : Senarai berganda.
Paling Sesuai Untuk : Sisipan dan pemadaman yang kerap.
Kelemahan : Masa capaian yang lebih perlahan disebabkan oleh lintasan penunjuk.
Kes Penggunaan : Melaksanakan senarai main di mana lagu sering ditambahkan atau dialih keluar.
List<String> linkedList = new LinkedList<>(); linkedList.add("Node1"); linkedList.add("Node2");
Reka Letak Memori : LinkedLists menggunakan memori bukan bersebelahan dengan setiap nod menghala ke nod sebelumnya dan seterusnya.c. CopyOnWriteArrayList
Tujuan Khas : Varian ArrayList selamat benang.
Cara ia Berfungsi : Mencipta salinan baharu tatasusunan asas pada setiap pengubahsuaian.
Paling Sesuai Untuk : Senario di mana bacaan jauh melebihi jumlah penulisan, cth., menyimpan cache data yang kerap diakses.
Kelemahan : Memori intensif dan lambat untuk kemas kini.
d. Vektor
Legasi : Diperkenalkan dalam Java 1.0.
Keselamatan Benang : Penyegerakan overhed menjadikannya lebih perlahan daripada alternatif moden.
Fakta Seronok : Seperti ‘lawak ayah’ List—tidak kelakar sebenarnya tetapi masih berkeliaran.
List<String> arrayList = new ArrayList<>(); arrayList.add("First"); arrayList.add("Second");
List<String> linkedList = new LinkedList<>(); linkedList.add("Node1"); linkedList.add("Node2");
Nota: Ini mengembalikan senarai saiz tetap, jadi anda tidak boleh menambah atau mengalih keluar elemen.
List<String> list = new ArrayList<>();
Tidak boleh ubah bermaksud tiada tambah(), buang(), atau clear()—seperti jiran yang tidak membenarkan sesiapa menyentuh rumput mereka.
List<String> list = Arrays.asList("A", "B", "C");
b. tambah(indeks int, elemen E)
Memasukkan elemen pada indeks yang ditentukan, mengalihkan elemen seterusnya.
List<String> immutableList = List.of("X", "Y", "Z");
c. alih keluar(int index)
Mengalih keluar elemen pada indeks yang ditentukan.
list.add("Element");
d. dapatkan(int index)
Mendapatkan semula elemen pada indeks yang ditentukan.
list.add(1, "Middle");
e. set(int index, elemen E)
Menggantikan elemen pada kedudukan yang ditentukan dengan elemen baharu.
list.remove(0);
String element = list.get(2);
Apabila diubah saiz:
list.set(1, "UpdatedElement");
b. Dalaman LinkedList Setiap elemen (nod) dalam LinkedList mengandungi:
Data
Tuding ke nod seterusnya
Tuding ke nod sebelumnya (dalam senarai terpaut dua kali)
Perjalanan lebih perlahan kerana mengakses indeks memerlukan lelaran melalui nod.
Rajah :
[Element1] [Element2] [Element3] [Null] ... [Null]
[Element1] [Element2] [Element3] [NewElement] [Null] ... [Null]
Algoritma Pencarian :
Carian Linear : O(n) – Imbas setiap elemen.
Carian Binari : O(log n) – Memerlukan senarai yang diisih.
List<String> arrayList = new ArrayList<>(); arrayList.add("First"); arrayList.add("Second");
List<String> linkedList = new LinkedList<>(); linkedList.add("Node1"); linkedList.add("Node2");
Benarkan Pendua : Sama sekali.
Operasi Akses Kerap : Go ArrayList.
Pengubahsuaian Kerap : Go LinkedList.
List<String> list = new ArrayList<>();
List<String> list = Arrays.asList("A", "B", "C");
List<String> immutableList = List.of("X", "Y", "Z");
list.add("Element");
Gunakan Generik : Sentiasa nyatakan jenis untuk mengelakkan ClassCastException.
Jangan Gunakan ArrayList<>() baharu dalam Gelung : Gunakan semula kejadian atau urus dengan betul untuk mengelakkan OutOfMemoryError.
Senarai Pemahaman dengan teliti membolehkan anda menulis program Java yang cekap, boleh skala dan boleh dibaca. Ia seperti menguasai asas memasak sebelum terjun ke resipi gourmet—anda akan menyelamatkan diri daripada kod hangus (dan roti bakar hangus). Jangan ragu untuk bermain dengan contoh, buat senario tersuai dan terima kuasa Senarai. Dan ingat, pembangun yang berpengalaman tahu bahawa setiap elemen penting, dalam kehidupan dan dalam Senarai.
Sekarang maju, takluki cabaran pengekodan anda dengan penguasaan Senarai baharu anda dan jangan biarkan tatasusunan anda menguasai anda lagi!
Atas ialah kandungan terperinci Panduan Terbaik untuk Senarai di Java: Semua yang Anda Perlu Tahu. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!