Java Concurrency - BlockingQueue Interface

Antarmuka java.util.concurrent.BlockingQueue adalah subinterface Antarmuka Antrean, dan juga mendukung operasi seperti menunggu antrean menjadi tidak kosong sebelum mengambil elemen, dan menunggu ruang tersedia dalam antrean sebelum menyimpan elemen .

Metode BlockingQueue

Sr.No. Metode & Deskripsi
1

boolean add(E e)

Menyisipkan elemen yang ditentukan ke dalam antrean ini jika memungkinkan untuk dilakukan segera tanpa melanggar batasan kapasitas, mengembalikan nilai true setelah berhasil dan menampilkan IllegalStateException jika tidak ada ruang yang tersedia saat ini.

2

boolean contains(Object o)

Mengembalikan nilai benar jika antrian ini berisi elemen yang ditentukan.

3

int drainTo(Collection<? super E> c)

Menghapus semua elemen yang tersedia dari antrian ini dan menambahkannya ke koleksi yang diberikan.

4

int drainTo(Collection<? super E> c, int maxElements)

Menghapus maksimal sejumlah elemen yang tersedia dari antrean ini dan menambahkannya ke koleksi yang diberikan.

5

boolean offer(E e)

Menyisipkan elemen yang ditentukan ke dalam antrian ini jika memungkinkan untuk melakukannya segera tanpa melanggar batasan kapasitas, mengembalikan nilai true setelah berhasil dan false jika tidak ada ruang yang tersedia saat ini.

6

boolean offer(E e, long timeout, TimeUnit unit)

Menyisipkan elemen yang ditentukan ke dalam antrian ini, menunggu hingga waktu tunggu yang ditentukan jika perlu agar ruang tersedia.

7

E poll(long timeout, TimeUnit unit)

Mengambil dan menghapus kepala antrean ini, menunggu hingga waktu tunggu yang ditentukan jika perlu agar elemen tersedia.

8

void put(E e)

Menyisipkan elemen yang ditentukan ke dalam antrian ini, menunggu jika perlu sampai ruang tersedia.

9

int remainingCapacity()

Mengembalikan jumlah elemen tambahan yang idealnya dapat diterima antrean ini (jika tidak ada batasan memori atau sumber daya) tanpa pemblokiran, atau Integer.MAX_VALUE jika tidak ada batas intrinsik.

10

boolean remove(Object o)

Menghapus satu instance dari elemen yang ditentukan dari antrian ini, jika ada.

11

E take()

Mengambil dan menghapus kepala antrean ini, menunggu jika perlu hingga elemen tersedia.

Contoh

Program TestThread berikut menunjukkan penggunaan antarmuka BlockingQueue di lingkungan berbasis thread.

import java.util.Random;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;

public class TestThread {

   public static void main(final String[] arguments) throws InterruptedException {
      BlockingQueue<Integer> queue = new ArrayBlockingQueue<Integer>(10);

      Producer producer = new Producer(queue);
      Consumer consumer = new Consumer(queue);

      new Thread(producer).start();
      new Thread(consumer).start();

      Thread.sleep(4000);
   }  


   static class Producer implements Runnable {
      private BlockingQueue<Integer> queue;

      public Producer(BlockingQueue queue) {
         this.queue = queue;
      }

      @Override
      public void run() {
         Random random = new Random();

         try {
            int result = random.nextInt(100);
            Thread.sleep(1000);
            queue.put(result);
            System.out.println("Added: " + result);
            
            result = random.nextInt(100);
            Thread.sleep(1000);
            queue.put(result);
            System.out.println("Added: " + result);
            
            result = random.nextInt(100);
            Thread.sleep(1000);
            queue.put(result);
            System.out.println("Added: " + result);
         } catch (InterruptedException e) {
            e.printStackTrace();
         }
      }	   
   }

   static class Consumer implements Runnable {
      private BlockingQueue<Integer> queue;

      public Consumer(BlockingQueue queue) {
         this.queue = queue;
      }
      
      @Override
      public void run() {
         
         try {
            System.out.println("Removed: " + queue.take());
            System.out.println("Removed: " + queue.take());
            System.out.println("Removed: " + queue.take());
         } catch (InterruptedException e) {
            e.printStackTrace();
         }
      }
   }
}

Ini akan menghasilkan hasil sebagai berikut.

Keluaran

Added: 52
Removed: 52
Added: 70
Removed: 70
Added: 27
Removed: 27