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.