Array dan ArrayList adalah struktur data berbasis indeks yang sering digunakan dalam program Java. Secara konseptual, ArrayList didukung secara internal oleh array, namun, memahami perbedaan antara keduanya adalah kunci untuk menjadi pengembang Java yang hebat. Ini langkah yang cukup mendasar untuk memulai, terutama pemula yang baru saja mulai coding. Walaupun keduanya digunakan untuk menyimpan elemen di Jawa, yang bisa berupa primitif atau objek, mereka memiliki perbedaan yang adil dalam hal fungsi dan kinerja. Perbedaan utama antara keduanya adalah bahwa Array bersifat statis sedangkan ArrayList bersifat dinamis. Artikel ini membandingkan keduanya pada berbagai aspek sehingga Anda dapat memilih satu dari yang lain.
Salah satu perbedaan utama dan nyata antara dua struktur data adalah bahwa Array bersifat statis yang berarti itu adalah tipe data panjang tetap sedangkan ArrayList bersifat dinamis yang berarti itu adalah struktur data panjang variabel. Dalam istilah teknis, panjang Array tidak dapat diubah atau dimodifikasi setelah objek Array dibuat. Ini berisi kumpulan elemen berurutan dari tipe data yang sama. Array di Java bekerja secara berbeda dari fungsinya di C / C ++. ArrayList, di sisi lain, dapat mengubah ukuran sendiri dan array dapat tumbuh sesuai kebutuhan. Karena ini adalah struktur data dinamis, elemen dapat ditambahkan dan dihapus dari daftar.
Anda tidak dapat membuat Array Generik kelas antarmuka di Jawa sehingga array dan generik tidak berjalan seiring sehingga tidak mungkin untuk membuat Generic Array karena satu alasan dasar bahwa array adalah kovarian sementara generik tidak tetap. Sementara Array adalah struktur data panjang tetap, itu berisi objek dari kelas yang sama atau primitif dari tipe data tertentu. Jadi jika Anda mencoba untuk menyimpan tipe data berbeda dari yang ditentukan saat membuat objek Array, itu hanya melempar "ArrayStoreException". ArrayList, di sisi lain, mendukung Generics untuk memastikan keamanan jenis.
Tipe data primitif seperti int, dobel, panjang, dan char tidak diizinkan di ArrayList. Itu lebih memegang benda-benda dan primitif tidak dianggap objek di Jawa. Array, di sisi lain, dapat menyimpan primitif serta objek di Jawa karena merupakan salah satu struktur data paling efisien di Jawa untuk menyimpan objek. Ini adalah tipe data agregat yang dirancang untuk menampung objek yang bisa tipe yang sama atau berbeda.
Untuk mendapatkan panjang Array, kode perlu mengakses atribut panjang karena kita harus tahu panjang untuk melakukan operasi pada Array. Sementara ArrayList menggunakan metode size () untuk menentukan ukuran ArrayList, itu agak berbeda dari menentukan panjang Array. Atribut size () method menentukan jumlah elemen dalam ArrayList, yang pada gilirannya adalah kapasitas ArrayList.
Sebagai contoh:
kelas publik ArrayLengthTest
public static public void (String [] args)
ArrayList arrList = new ArrayList ();
String [] item = “One”, “Two”, “Three”;
untuk (String str: items)
arrList.add (str);
int size = items.size ();
System.out.println (ukuran);
Array adalah komponen pemrograman asli di Jawa yang dibuat secara dinamis dan mereka menggunakan operator penugasan untuk menahan elemen, sedangkan ArrayList menggunakan atribut add () untuk menyisipkan elemen. ArrayList adalah kelas dari framework koleksi di Jawa yang menggunakan seperangkat metode yang ditentukan untuk mengakses dan memodifikasi elemen. Ukuran ArrayList dapat ditingkatkan atau diturunkan secara dinamis. Elemen-elemen dalam array disimpan di lokasi memori yang berdekatan dan ukurannya tetap statis di seluruh.
Sementara kedua struktur data menyediakan kinerja yang serupa dengan ArrayList didukung oleh Array, satu memiliki sedikit keunggulan dibandingkan yang lain dalam hal waktu CPU dan penggunaan memori. Katakanlah, jika Anda mengetahui ukuran array, Anda cenderung menggunakan ArrayList. Namun, iterasi pada Array sedikit lebih cepat daripada iterasi pada ArrayList. Jika program melibatkan sejumlah besar primitif, sebuah array akan berkinerja lebih baik secara signifikan daripada ArrayList, dalam hal waktu dan memori. Array adalah bahasa pemrograman tingkat rendah yang dapat digunakan dalam implementasi koleksi. Namun, kinerja dapat bervariasi tergantung pada operasi yang Anda lakukan.
Himpunan | ArrayList |
Array adalah struktur data panjang tetap yang panjangnya tidak dapat dimodifikasi begitu objek array dibuat. | ArrayList bersifat dinamis yang artinya dapat mengubah ukurannya sendiri untuk tumbuh bila diperlukan. |
Ukuran array tetap statis di seluruh program. | Ukuran ArrayList dapat tumbuh secara dinamis tergantung pada beban dan kapasitas. |
Ini menggunakan operator penugasan untuk menyimpan elemen. | Ini menggunakan atribut add () untuk menyisipkan elemen. |
Itu bisa berisi primitif serta objek dari tipe data yang sama atau berbeda. | Primitif tidak diizinkan di ArrayList. Itu hanya bisa berisi tipe objek. |
Array dan Generics tidak berjalan seiring. | Generik diizinkan di ArrayList. |
Array bisa multi-dimensional. | ArrayList adalah dimensi tunggal. |
Ini adalah komponen pemrograman asli di mana elemen disimpan di lokasi memori yang berdekatan. | Ini adalah kelas dari kerangka koleksi Java di mana objek tidak pernah disimpan di lokasi yang berdekatan. |
Variabel panjang digunakan untuk menentukan panjang Array. | Metode Size () digunakan untuk menentukan ukuran ArrayList. |
Membutuhkan lebih sedikit memori daripada ArrayList untuk menyimpan elemen atau objek yang ditentukan. | Membutuhkan lebih banyak memori daripada Array untuk menyimpan objek. |
Iterasi melalui array lebih cepat daripada iterasi di atas ArrayList. | Iterasi lebih dari ArrayList secara signifikan lebih lambat dalam hal kinerja. |
Sementara beberapa orang mungkin berpikir bahwa menerapkan array dalam suatu program dapat memperoleh hasil lebih cepat daripada melakukan hal yang sama dengan ArrayLists karena alasan sederhana bahwa array adalah struktur data tingkat rendah, kinerja dapat bervariasi berdasarkan pada operasi apa yang Anda lakukan. Nah, panjang Array adalah tetap, sedangkan ukuran ArrayList dapat dinaikkan atau diturunkan secara dinamis, sehingga ArrayList memiliki sedikit keunggulan dibandingkan Array dalam hal fungsionalitas. Namun, meskipun ada perbedaan, mereka juga memiliki beberapa kesamaan. Keduanya adalah struktur data berbasis indeks di Jawa yang memungkinkan Anda untuk menyimpan objek dan keduanya memungkinkan nilai nol serta duplikat. Nah, jika Anda tahu ukuran objek sebelumnya, Anda harus pergi dengan array, dan jika Anda tidak yakin tentang ukurannya, pergi dengan ArrayList.