Dengan populariti pemproses berbilang teras, pengaturcara telah mula memberi perhatian kepada masalah akses serentak kepada data Bagi menyelesaikan masalah keselamatan benang, Java menyediakan pelbagai bekas serentak. Artikel ini akan memperkenalkan beberapa bekas serentak Java biasa.
ConcurrentHashMap ialah jadual cincang selamat benang. Ia pada asasnya adalah pelaksanaan yang sama seperti HashMap, tetapi ConcurrentHashMap menyokong operasi pengubahsuaian konkurensi tinggi, jadi ia lebih sesuai untuk senario berbilang benang daripada HashMap.
ConcurrentHashMap mempunyai berbilang kunci segmen di dalam, setiap kunci melindungi baldi cincang, supaya berbilang utas boleh mengubah suai baldi berbeza secara serentak. Reka bentuk ini membolehkan ConcurrentHashMap mencapai pemisahan baca dan tulis yang cekap.
Langkah-langkah untuk menggunakan ConcurrentHashMap adalah seperti berikut:
ConcurrentMap<Integer, String> map = new ConcurrentHashMap<>();
map.put(1, "one");
String value = map.get(1);
CopyOnWriteArrayList ialah tatasusunan dinamik selamat benang. Cirinya ialah operasi tulis tidak mengubah suai tatasusunan asal secara langsung, tetapi mencipta tatasusunan baharu untuk pengubahsuaian, dan kemudian menggantikan tatasusunan asal dengan tatasusunan baharu. Memandangkan operasi pengubahsuaian dan operasi baca tidak bercanggah, CopyOnWriteArrayList menyokong operasi baca serentak yang tinggi.
Langkah-langkah untuk menggunakan CopyOnWriteArrayList adalah seperti berikut:
List<String> list = new CopyOnWriteArrayList<>();
list.add("one");
String value = list.get(0);
Perlu diambil perhatian bahawa memandangkan setiap pengubahsuaian memerlukan penciptaan tatasusunan baru, operasi pengubahsuaian CopyOnWriteArrayList adalah agak perlahan dan tidak sesuai untuk tinggi -operasi penulisan kekerapan.
ConcurrentLinkedQueue ialah baris gilir selamat benang. Pelaksanaannya adalah berdasarkan senarai terpaut dan menyokong operasi enqueue dan dequeue concurrency tinggi.
ConcurrentLinkedQueue secara dalaman menggunakan operasi CAS untuk melaksanakan pengubahsuaian serentak pada senarai terpaut, sekali gus mengelakkan masalah prestasi yang disebabkan oleh penggunaan kunci.
Langkah-langkah untuk menggunakan ConcurrentLinkedQueue adalah seperti berikut:
Queue<String> queue = new ConcurrentLinkedQueue<>();
queue.offer("one");
String value = queue.poll();
Perlu diingatkan bahawa ConcurrentLinkedQueue tidak menyokong akses rawak, jadi ia hanya boleh dilalui dari kepala baris gilir.
ConcurrentSkipListMap ialah jadual pemetaan tertib yang selamat untuk benang. Pelaksanaannya adalah berdasarkan jadual langkau dan boleh menyokong operasi sisipan, pemadaman dan carian dengan cepat.
Serupa dengan ConcurrentHashMap, ConcurrentSkipListMap juga dibahagikan kepada berbilang peringkat Setiap peringkat mempunyai set senarai terpautnya sendiri, yang boleh meningkatkan kecekapan akses serentak.
Langkah-langkah untuk menggunakan ConcurrentSkipListMap adalah seperti berikut:
ConcurrentNavigableMap<Integer, String> map = new ConcurrentSkipListMap<>();
String value = map.get(1);
Atas ialah kandungan terperinci Bekas serentak di Jawa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!