Rumah >Java >javaTutorial >Bagaimana untuk Melaksanakan Benang Pengeluar/Pengguna dengan Baris Gilir?

Bagaimana untuk Melaksanakan Benang Pengeluar/Pengguna dengan Baris Gilir?

Susan Sarandon
Susan Sarandonasal
2024-12-05 14:54:12221semak imbas

How to Implement Producer/Consumer Threads with a Queue?

Benang Pengeluar/Pengguna dengan Barisan Beratur

Untuk mewujudkan benang pengeluar/pengguna dengan baris gilir, terdapat dua komponen utama: perkhidmatan pelaksana dan, jika perlu, penyekatan beratur.

Perkhidmatan Pelaksana

Mulakan dengan meletakkan semua pengeluar dalam satu perkhidmatan pelaksana dan semua pengguna dalam perkhidmatan lain.

Baris Gilir Menyekat

Jika komunikasi antara perkhidmatan diperlukan, gunakan baris gilir menyekat. Contohnya:

final ExecutorService producers = Executors.newFixedThreadPool(100);
final ExecutorService consumers = Executors.newFixedThreadPool(100);
while (/* has more work */) {
  producers.submit(...);
}
producers.shutdown();
producers.awaitTermination(Long.MAX_VALUE, TimeUnit.NANOSECONDS);
consumers.shutdown();
consumers.awaitTermination(Long.MAX_VALUE, TimeUnit.NANOSECONDS);

Pertimbangan Pelaksanaan

Urutan pengeluar menyerahkan tugas terus kepada urutan pengguna, dan bukannya menggunakan baris gilir sekatan yang berasingan untuk komunikasi. Pendekatan ini memudahkan pelaksanaan sambil mengekalkan keselarasan dan kecekapan.

Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Benang Pengeluar/Pengguna dengan Baris Gilir?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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