Rumah > Java > javaTutorial > teks badan

Bekas serentak di Jawa

王林
Lepaskan: 2023-06-08 09:54:27
asal
1258 orang telah melayarinya

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.

  1. ConcurrentHashMap

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:

  1. Buat contoh ConcurrentHashMap:
ConcurrentMap<Integer, String> map = new ConcurrentHashMap<>();
Salin selepas log masuk
  1. Tambah elemen:
map.put(1, "one");
Salin selepas log masuk
Salin selepas log masuk
  1. Dapatkan elemen:
String value = map.get(1);
Salin selepas log masuk
Salin selepas log masuk
  1. CopyOnWriteArrayList

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:

  1. Buat contoh CopyOnWriteArrayList:
List<String> list = new CopyOnWriteArrayList<>();
Salin selepas log masuk
  1. Tambah elemen:
list.add("one");
Salin selepas log masuk
  1. Dapatkan elemen:
String value = list.get(0);
Salin selepas log masuk

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.

  1. ConcurrentLinkedQueue

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:

  1. Buat contoh ConcurrentLinkedQueue:
Queue<String> queue = new ConcurrentLinkedQueue<>();
Salin selepas log masuk
  1. Operasi baris gilir:
queue.offer("one");
Salin selepas log masuk
  1. Operasi dequeue:
String value = queue.poll();
Salin selepas log masuk

Perlu diingatkan bahawa ConcurrentLinkedQueue tidak menyokong akses rawak, jadi ia hanya boleh dilalui dari kepala baris gilir.

  1. ConcurrentSkipListMap

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:

  1. Buat contoh ConcurrentSkipListMap:
ConcurrentNavigableMap<Integer, String> map = new ConcurrentSkipListMap<>();
Salin selepas log masuk
  1. Tambah elemen:
  2. <🎜
    map.put(1, "one");
    Salin selepas log masuk
    Salin selepas log masuk
    Dapatkan elemen:
  1. String value = map.get(1);
    Salin selepas log masuk
    Salin selepas log masuk
    Perlu diambil perhatian bahawa pelaksanaan ConcurrentSkipListMap adalah lebih rumit, jadi dalam kes volum data yang kecil, prestasi mungkin lebih teruk daripada TreeMap.

    Ringkasan

    Java menyediakan pelbagai bekas serentak, dan pengaturcara boleh memilih bekas yang sesuai mengikut keperluan mereka. Perlu diingatkan bahawa bekas yang berbeza mempunyai senario terpakai yang berbeza, dan penggunaan yang tidak betul boleh menyebabkan masalah prestasi Oleh itu, adalah disyorkan untuk memilih bekas yang sesuai mengikut senario.

    Atas ialah kandungan terperinci Bekas serentak di Jawa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan