Java Thread How to - Use BlockingQueue.take method








Question

We would like to know how to use BlockingQueue.take method.

Answer

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.atomic.AtomicLong;
/*from   w  ww  .  java  2 s .  c o  m*/
public class Main {
  public static void main(String[] args) throws Exception {
    Runner t = new Runner();
    Thread t1 = new Thread(t);
    for (int i = 0; i < 50; i++) {
      t.queue.add(i);
    }
    System.out.println(("Number of items in queue: " + t.queue.size()));
    t1.start();
    Thread.sleep(1000);
    t1.interrupt();
    t1.join();
    System.out.println(("Number of items in queue: " + t.queue.size()));
    System.out.println(("Joined t1. Finished"));
  }
}
class Runner implements Runnable {
  BlockingQueue<Integer> queue = new ArrayBlockingQueue<Integer>(100);
  AtomicLong m_count = new AtomicLong(0);
  @Override
  public void run() {
    try {
      while (true) {
        queue.take();
        System.out.println("Took item " + m_count.incrementAndGet());
        final long start = System.currentTimeMillis();
        while ((System.currentTimeMillis() - start) < 100) {
          Thread.yield(); // Spin wait
        }
      }
    } catch (Exception ex) {
      System.out.println("Interrupted. Count: " + m_count.get());
    }
  }
}

The code above generates the following result.