內容主要來自jdk的api,大家可參考jdkapi
1.BlockingQueue:支持兩個附加操作的 Queue,這兩個操作是:檢索元素時等待隊列變爲非空,以及存儲元素時等待空間變得可用。
2.BlockingQueue 不接受 null 元素。
3.BlockingQueue 可以是限定容量的。
4.BlockingQueue 實現是線程安全的。Queue不是線程安全的。因此可以將Blockingqueue用於用於生產者-使用者隊列。
根據Api修改的一個例子,大家可以修改自己體驗BlockingQueue的使用
package test; import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.BlockingQueue; /** * 生產者 * @author wasw100 */ class Producer implements Runnable { private final BlockingQueue queue; Producer(BlockingQueue q) { queue = q; } public void run() { try { for (int i = 0; i < 3; i++) { queue.put(produce()); System.out.println("生產後:"+queue.peek()); } } catch (InterruptedException ex) { ex.printStackTrace(); } } Character produce() { char c = (char) (Math.random() * 26 + 'A'); System.out.println("生產前:" + c); return c; } } /** * 消費者 * @author wasw100 */ class Consumer implements Runnable { private final BlockingQueue queue; Consumer(BlockingQueue q) { queue = q; } public void run() { try { while (true) { consume(queue.take()); //Thread.sleep(100); } } catch (InterruptedException ex) { ex.printStackTrace(); } } void consume(Character c) { System.out.println("消費:" + c); } } /** * 一個生產者、兩個消費者 * * @author wasw100 */ class Setup { public static void main(String[] args) { BlockingQueue q = new ArrayBlockingQueue(1); Producer p = new Producer(q); Consumer c1 = new Consumer(q); Consumer c2 = new Consumer(q); new Thread(p).start(); new Thread(c1).start(); new Thread(c2).start(); } }
–EOF–