- 相關(guān)推薦
關(guān)于Java中Queue和BlockingQueue的區(qū)別
隊(duì)列是一種特殊的線性表,它只允許在表的前端(front)進(jìn)行刪除操作,而在表的后端(rear)進(jìn)行插入操作。進(jìn)行插入操作的端稱為隊(duì)尾,進(jìn)行刪除操作的端稱為隊(duì)頭。隊(duì)列中沒有元素時(shí),稱為空隊(duì)列。下面小編準(zhǔn)備了關(guān)于Java中Queue和BlockingQueue的區(qū)別,提供給大家參考!
1.BlockingQueue:支持兩個(gè)附加操作的 Queue,這兩個(gè)操作是:檢索元素時(shí)等待隊(duì)列變?yōu)榉强,以及存?chǔ)元素時(shí)等待空間變得可用。
2.BlockingQueue 不接受 null 元素。
3.BlockingQueue 可以是限定容量的。
4.BlockingQueue 實(shí)現(xiàn)是線程安全的。Queue不是線程安全的。因此可以將Blockingqueue用于用于生產(chǎn)者-使用者隊(duì)列。
根據(jù)Api修改的一個(gè)例子,大家可以修改自己體驗(yàn)BlockingQueue的使用
package test;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
/**
* 生產(chǎn)者
*/
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("生產(chǎn)后:"+queue.peek());
}
} catch (InterruptedException ex) {
ex.printStackTrace();
}
}
Character produce() {
char c = (char) (Math.random() * 26 + 'A');
System.out.println("生產(chǎn)前:" + c);
return c;
}
}
/**
* 消費(fèi)者
*/
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("消費(fèi):" + c);
}
}
/**
* 一個(gè)生產(chǎn)者、兩個(gè)消費(fèi)者
*
*/
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–
【Java中Queue和BlockingQueue的區(qū)別】相關(guān)文章:
JAVA和.NET開發(fā)過程中的區(qū)別04-27
PHP中MySQL、MySQLi和PDO的用法和區(qū)別08-29
跆拳道中WTF和ITF的區(qū)別11-01
j2ee與java的區(qū)別04-01
PETS和CET的區(qū)別08-18
戲曲和話劇的區(qū)別05-08
自考和電大的區(qū)別09-04
flash源文件中fla文件和swf文件有什么區(qū)別03-30
白茶和老白茶的區(qū)別02-08