一、UML类图
1 BlockingQueue 的用法:
在 JDK中对 BlockingQueue的描述是这样的:
获取元素时等待队列变为非空,以及存储元素时等待空间变得可用。
其意思为一个线程往BlockingQueue放元素,另外一个线程从 BlockingQueue里边取元素。
假若一个生产线程将会持续的将对象插入到队列之中,当队列满了,则这个生产线程会被阻塞,直到负责消费的线程从队列中拿走一个对象。
负责消费的线程将会一直从该阻塞队列中拿出对象,如果消费线程尝试去从一个空的队列中提取对象的话,这个消费线程将会被阻塞,直到一个生产线程把一个对象丢进队列。
假若一个生产线程将会持续的将对象插入到队列之中,当队列满了,则这个生产线程会被阻塞,直到负责消费的线程从队列中拿走一个对象。
负责消费的线程将会一直从该阻塞队列中拿出对象,如果消费线程尝试去从一个空的队列中提取对象的话,这个消费线程将会被阻塞,直到一个生产线程把一个对象丢进队列。
2 BlockingQueue 的方法:
一共4 组不同的方法用于插入、移除以及对队列中的元素进行检查。如果请求的操作不能得到立即执行的话,每个方法的表现也不同。
二、API
三、使用案例
1.利用队列的put()与take()的阻塞特性实现线程通信
package com.dason.second;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
/**
* 使用队列的阻塞性实现线程通信
* 1.put():向队列中存入数据.当队列已满,等待直到有可用的空间.
* 2.take():从队列中取出数据.当队列为空,等待直到队列中有元素.
* @author Dason
*
*/
public class BlockingQueueCommunication {
public static void main(String[] args) {
final Business business = new Business();
new Thread(
new Runnable() {
@Override
public void run() {
while(true) {
business.sub("子线程");
}
}
}
).start();
while(true) {
business.main("主线程");
}
}
static class Business {
BlockingQueue<Integer> queue1 = new ArrayBlockingQueue<Integer>(1);
BlockingQueue<Integer> queue2 = new ArrayBlockingQueue<Integer>(1);
//匿名构造方法:每次创建该类的实例时,在实名构造方法前被调用
{
try {
queue2.put(1);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public void sub(String str){
try {
queue1.put(1);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(str);
try {
queue2.take();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public void main(String str){
try {
queue2.put(1);
} catch (InterruptedException e1) {
e1.printStackTrace();
}
System.out.println(str);
try {
queue1.take();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}