Mengalih Keluar Pendua daripada Senarai dengan Cekap
Apabila bekerja dengan senarai, selalunya perlu mengalih keluar elemen pendua untuk menyelaraskan pemprosesan data. Walau bagaimanapun, coretan kod berikut mungkin menghadapi isu:
List<Customer> listCustomer = new ArrayList<>(); for (Customer customer: tmpListCustomer) { if (!listCustomer.contains(customer)) { listCustomer.add(customer); } }
Apakah Hadnya?
Pendekatan ini bergantung pada kaedah contains() untuk menyemak pendua. Walau bagaimanapun, ia hanya berfungsi dengan betul jika kelas Pelanggan mengatasi kaedah equals() dan hashCode() untuk membandingkan objek dengan berkesan. Jika kaedah ini tidak dilaksanakan atau dilaksanakan secara salah, pendua mungkin tidak dapat dikesan, yang membawa kepada ketidaktepatan.
Teknik Penyingkiran Cekap
Untuk mengalih keluar pendua dengan berkesan, terdapat dua kaedah untuk dipertimbangkan:
Jika mengekalkan susunan elemen sedia ada adalah kritikal, gunakan LinkedHashSet. Set ini mengekalkan susunan sisipan, membolehkan anda menukarnya kembali kepada senarai sambil mengekalkan jujukan.
List<Customer> depdupeCustomers = new ArrayList<>(new LinkedHashSet<>(customers));
Jika mengubah suai senarai asal boleh diterima, gunakan Set untuk menyimpan elemen unik dan kemas kini senarai asal dengan sewajarnya.
Set<Customer> depdupeCustomers = new LinkedHashSet<>(customers); customers.clear(); customers.addAll(dedupeCustomers);
Kedua-dua kaedah menawarkan penyelesaian yang cekap untuk mengalih keluar pendua daripada senarai, memastikan integriti data dan mengoptimumkan prestasi .
Atas ialah kandungan terperinci Bagaimana untuk Mengeluarkan Pendua Dengan Cekap Dari Senarai di Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!