Belajar Code...
Kelas Map
Suatu array yang berisi N elemen bisa juga dilihat sebagai asosiasi (pemetaan) antara elemennya dengan bilangan 0, 1, ..., N-1 yang merupakan indeksnya. Jika i adalah salah satu bilangan ini, maka kita bisa mengambil elemen yang dipetakan oleh bilangan i, dan juga kita bisa meletakkan elemen baru pada posisi ke-i.
Suatu peta (map) adalah generalisasi dari array. Seperti array, map juga memiliki operasi untuk mengambil dan meletakkan elemen. Akan tetapi pada map, operasi ini tidak dilakukan pada bilangan 0, 1, ... N-1, akan tetapi pada sembarang
Object
.
Beberapa bahasa pemrograman menggunakan istilah array asosiatif (associative array) karena kesamaan perintah dengan array biasa. Pada bahasa pemrograman tersebut, kita bisa menuliskan
A["joko"]
yang digunakan untuk memetakan "joko" pada suatu elemen di dalam array.
Java tidak menggunakan perintah yang sama pada map, akan tetapi idenya serupa : Map adalah seperti array yang indeksnya adalah objek sembarang, bukan integer. Pada map, objek yang digunakan sebagai "indeks" disebut kunci (key). Objek yang ditunjuk oleh indeks tersebut disebut nilai (value).
Satu kunci hanya boleh menunjuk pada satu nilai, akan tetapi satu nilai bisa ditunjuk oleh beberapa kunci.
Dalam Java, map didefinisikan dalam interface
java.util.Map
, yang memiliki beberapa metode untuk bekerja dengan map. Jika map
adalah variabel dengan tipe Map
, maka berikut ini adalah beberapa metodenya :map.get(kunci)
-- mengembalikanObject
yang ditunjuk olehkunci
. Jika map tidak memiliki nilai yang ditunjuk olehkunci
, maka nilainull
akan dikembalikan. Tapi ingat juga bahwa mungkin saja kuncinya ada akan tetapi memang menunjuk pada nilainull
. Menggunakan "map.get(kunci)
" sama dengan perintah "A[kunci]
" pada array A. (Akan tetapi pada map tidak ada pengecualianIndexOutOfBoundsException
)map.put(kunci, nilai)
-- Mengisi map dengan pasangankunci
dannilai
. Kedua-duakunci
dannilai
bisa berupa objek apa saja. Jika map tersebut telah memilikikunci
maka nilai yang ditunjuk akan diganti dengan yang baru diberikan. Perintah ini mirip dengan "A[kunci] = nilai
" pada array.map.putAll(map2)
-- jikamap2
adalah map lain, maka perintah ini akan mengkopi semua isi padamap2
ke dalammap
.map.remove(kunci)
-- Jikamap
memilikikunci
yang menunjuk pada suatu nilai, perintah ini akan menghapuskunci
beserta nilai yang ditunjuknya, atau dengan kata lain menghapus pasangan kunci dan nilai pada map sekaligus.map.containsKey(kunci)
-- mengembalikan nilai boolean true jika map memilikikunci
yang merujuk pada suatu nilaimap.containsValue(nilai)
-- mengembalikan nilai boolean true jika map memilikinilai
yang ditunjuk oleh kunci apapun.map.size()
-- mengembalikanint
yang berisi jumlah pasangan asosiasi pada map.map.isEmpty()
-- mengembalikan boolean true jika map tidak berisi pasangan asosiasi apa-apa.map.clear()
-- menghapus semua pasangan asosiasi dalam map.
Metode
put
dan get
jelas merupakan metode yang paling sering digunakan dalam map. Dalam banyak aplikasi, metode ini mungkin hanya metode ini yang kita butuhkan. Artinya, menggunakan map sama mudahnya dengan menggunakan array biasa.
sumber: http://java.lyracc.com/print/131
Tidak ada komentar:
Posting Komentar
jangan lupa beri komentar dan join blognya yaa :)