Java - Kerangka Koleksi

Sebelum Java 2, Java menyediakan kelas ad hoc seperti Dictionary, Vector, Stack, dan Propertiesuntuk menyimpan dan memanipulasi kelompok objek. Meskipun kelas-kelas ini cukup berguna, mereka kekurangan tema sentral dan pemersatu. Jadi, cara Anda menggunakan Vektor berbeda dengan cara Anda menggunakan Properti.

Kerangka koleksi dirancang untuk memenuhi beberapa tujuan, seperti -

  • Kerangka harus berkinerja tinggi. Implementasi untuk koleksi fundamental (array dinamis, daftar tertaut, pohon, dan hashtable) harus sangat efisien.

  • Kerangka tersebut harus memungkinkan berbagai jenis koleksi untuk bekerja dengan cara yang sama dan dengan tingkat interoperabilitas yang tinggi.

  • Kerangka kerja harus memperluas dan / atau menyesuaikan koleksi dengan mudah.

Untuk tujuan ini, seluruh kerangka koleksi dirancang dengan seperangkat antarmuka standar. Beberapa implementasi standar sepertiLinkedList, HashSet, dan TreeSet, dari antarmuka ini disediakan yang dapat Anda gunakan sebagaimana adanya dan Anda juga dapat menerapkan koleksi Anda sendiri, jika Anda mau.

Kerangka koleksi adalah arsitektur terpadu untuk merepresentasikan dan memanipulasi koleksi. Semua kerangka koleksi berisi yang berikut -

  • Interfaces- Ini adalah tipe data abstrak yang mewakili koleksi. Antarmuka memungkinkan koleksi untuk dimanipulasi secara independen dari detail representasi mereka. Dalam bahasa berorientasi objek, antarmuka umumnya membentuk hierarki.

  • Implementations, i.e., Classes- Ini adalah implementasi konkret dari antarmuka koleksi. Intinya, mereka adalah struktur data yang dapat digunakan kembali.

  • Algorithms- Ini adalah metode yang melakukan komputasi berguna, seperti mencari dan mengurutkan, pada objek yang mengimplementasikan antarmuka koleksi. Algoritme dikatakan polimorfik: yaitu, metode yang sama dapat digunakan pada banyak implementasi berbeda dari antarmuka kumpulan yang sesuai.

Selain koleksi, kerangka kerja mendefinisikan beberapa antarmuka dan kelas peta. Pasangan kunci / nilai penyimpanan peta. Meskipun peta bukanlah koleksi dalam penggunaan yang tepat dari istilah tersebut, tetapi mereka sepenuhnya terintegrasi dengan koleksi.

Antarmuka Koleksi

Kerangka koleksi mendefinisikan beberapa antarmuka. Bagian ini memberikan gambaran umum dari setiap antarmuka -

Sr.No. Antarmuka & Deskripsi
1 Antarmuka Koleksi

Ini memungkinkan Anda untuk bekerja dengan kelompok objek; itu ada di bagian atas hierarki koleksi.

2 Antarmuka Daftar

Ini meluas Collection dan contoh Daftar menyimpan koleksi elemen yang dipesan.

3 Set

Koleksi ini memperluas untuk menangani set, yang harus berisi elemen unik.

4 The SortedSet

Ini memperluas Set untuk menangani set yang diurutkan.

5 Peta

Ini memetakan kunci unik ke nilai.

6 The Map.Entry

Ini mendeskripsikan elemen (pasangan kunci / nilai) di peta. Ini adalah kelas dalam dari Peta.

7 The SortedMap

Ini memperluas Peta sehingga kunci dipertahankan dalam urutan menaik.

8 Pencacahan

Ini adalah antarmuka warisan yang mendefinisikan metode yang dengannya Anda dapat menghitung (memperoleh satu per satu) elemen dalam kumpulan objek. Antarmuka lawas ini telah digantikan oleh Iterator.

Kelas Koleksi

Java menyediakan sekumpulan kelas koleksi standar yang mengimplementasikan antarmuka Collection. Beberapa kelas menyediakan implementasi lengkap yang dapat digunakan sebagaimana adanya dan yang lainnya adalah kelas abstrak, menyediakan implementasi kerangka yang digunakan sebagai titik awal untuk membuat koleksi konkret.

Kelas koleksi standar dirangkum dalam tabel berikut -

Sr.No. Kelas & Deskripsi
1

AbstractCollection

Menerapkan sebagian besar antarmuka Koleksi.

2

AbstractList

Memperluas AbstractCollection dan mengimplementasikan sebagian besar antarmuka Daftar.

3

AbstractSequentialList

Memperluas AbstractList untuk digunakan oleh koleksi yang menggunakan berurutan daripada akses acak elemennya.

4 LinkedList

Menerapkan daftar tertaut dengan memperluas AbstractSequentialList.

5 ArrayList

Menerapkan larik dinamis dengan memperluas AbstractList.

6

AbstractSet

Memperluas AbstractCollection dan mengimplementasikan sebagian besar antarmuka Set.

7 HashSet

Memperluas AbstractSet untuk digunakan dengan tabel hash.

8 LinkedHashSet

Memperluas HashSet untuk memungkinkan iterasi penyisipan-urutan.

9 TreeSet

Menerapkan satu set yang disimpan di pohon. Memperluas AbstractSet.

10

AbstractMap

Menerapkan sebagian besar antarmuka Peta.

11 HashMap

Memperluas AbstractMap untuk menggunakan tabel hash.

12 TreeMap

Memperluas AbstractMap untuk menggunakan pohon.

13 WeakHashMap

Memperluas AbstractMap untuk menggunakan tabel hash dengan kunci lemah.

14 LinkedHashMap

Memperluas HashMap untuk memungkinkan iterasi urutan penyisipan.

15 IdentityHashMap

Memperluas AbstractMap dan menggunakan persamaan referensi saat membandingkan dokumen.

Kelas AbstractCollection, AbstractSet, AbstractList, AbstractSequentialList dan AbstractMap menyediakan implementasi kerangka antarmuka koleksi inti, untuk meminimalkan upaya yang diperlukan untuk mengimplementasikannya.

Kelas warisan berikut yang didefinisikan oleh java.util telah dibahas di bab sebelumnya -

Sr.No. Kelas & Deskripsi
1 Vektor

Ini mengimplementasikan array dinamis. Ini mirip dengan ArrayList, tetapi dengan beberapa perbedaan.

2 Tumpukan

Stack adalah subclass dari Vector yang mengimplementasikan tumpukan standar terakhir masuk, keluar pertama.

3 Kamus

Kamus adalah kelas abstrak yang mewakili repositori penyimpanan kunci / nilai dan beroperasi seperti Map.

4 Hashtable

Hashtable adalah bagian dari java.util asli dan merupakan implementasi konkret dari sebuah Dictionary.

5 Properti

Properti adalah subclass dari Hashtable. Ini digunakan untuk memelihara daftar nilai di mana kuncinya adalah String dan nilainya juga String.

6 BitSet

Kelas BitSet membuat tipe larik khusus yang menyimpan nilai bit. Larik ini dapat bertambah besar sesuai kebutuhan.

Algoritma Koleksi

Kerangka koleksi mendefinisikan beberapa algoritma yang dapat diterapkan pada koleksi dan peta. Algoritme ini didefinisikan sebagai metode statis dalam kelas Koleksi.

Beberapa metode dapat melempar file ClassCastException, yang terjadi saat dilakukan upaya untuk membandingkan jenis yang tidak kompatibel, atau file UnsupportedOperationException, yang terjadi saat dilakukan upaya untuk mengubah koleksi yang tidak dapat dimodifikasi.

Koleksi menentukan tiga variabel statis: EMPTY_SET, EMPTY_LIST, dan EMPTY_MAP. Semuanya tidak berubah.

Sr.No. Algoritma & Deskripsi
1 Algoritma Koleksi

Berikut adalah daftar semua implementasi algoritma.

Bagaimana Cara Menggunakan Iterator?

Seringkali, Anda ingin menggilir elemen-elemen dalam koleksi. Misalnya, Anda mungkin ingin menampilkan setiap elemen.

Cara termudah untuk melakukannya adalah dengan menggunakan iterator, yang merupakan objek yang mengimplementasikan antarmuka Iterator atau ListIterator.

Iterator memungkinkan Anda untuk menggilir koleksi, mendapatkan atau menghapus elemen. ListIterator memperluas Iterator untuk memungkinkan traversal dua arah dari daftar dan modifikasi elemen.

Sr.No. Metode & Deskripsi Iterator
1 Menggunakan Java Iterator

Berikut adalah daftar semua metode dengan contoh yang disediakan oleh antarmuka Iterator dan ListIterator.

Bagaimana Cara Menggunakan Komparator?

Baik TreeSet dan TreeMap menyimpan elemen dalam urutan yang diurutkan. Namun, itu adalah pembanding yang mendefinisikan dengan tepat apa arti urutan yang diurutkan .

Antarmuka ini memungkinkan kita mengurutkan koleksi tertentu dengan berbagai cara. Antarmuka ini juga dapat digunakan untuk mengurutkan setiap instance dari kelas apa pun (bahkan kelas yang tidak dapat kami modifikasi).

Sr.No. Metode & Deskripsi Iterator
1 Menggunakan Java Comparator

Berikut adalah daftar semua metode dengan contoh-contoh yang disediakan oleh Comparator Interface.

Ringkasan

Kerangka koleksi Java memberi programmer akses ke struktur data yang dikemas serta ke algoritme untuk memanipulasinya.

Koleksi adalah objek yang dapat menampung referensi ke objek lain. Antarmuka koleksi mendeklarasikan operasi yang dapat dilakukan pada setiap jenis koleksi.

Kelas dan antarmuka kerangka koleksi ada dalam paket java.util.