java中Queue和BlockingQueue的區別

內容主要來自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–

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章