多线程设计模式之Producer Consumer模式
Producer Consumer模式与Guarded Suspension模式类似(其实多线程模式都很类似,只是解决的特定问题域不同。个人意见^_^)。在Guarded Suspension模式中,我们没有对多个线程间所争用的资源进行数量的控制,而Producer Consumer模式则专门用来解决这一问题域。
下面我们加载一个场景,让大家和我一起来逐步理解什么是Producer Consumer模式:
2050年的某自动化生产工厂,生产机器人(Producer)负责生产产品(Product),生产的产品通过传送带(AutoCarryStrip)输送给产品测试机器人(这里可以将其看作产品的Consumer)进行测试,测试完成后装箱。这里,传送带由于负载原因,当承载量最大时,所有的工人必须停止生产产品。
我们回到现在,按OO的思想来进行抽象和分析,以下是我们需要实现的主要类、职责及其与其它类的关系(可以称其为CRC卡片):
|
类名 |
Producer |
协作类及关系描述 |
|
职责 |
1. Product:产品,生产机器人的产出者 2. AutoCarryStrip:传送带,生产的产品将被放到其上,有最大承载量限制 |
|
|
在传送带的承载量未达到最大时负责生产产品,并将其放置到传送带上。 |
||
|
类名 |
Consumer |
协作类及关系描述 |
|
职责 |
1. Product:产品,从工作台上取下的待测试产品。 2. AutoCarryStrip:传送带,测试者将从其上取下产品 |
|
|
负责在传送带上有产品时,取下产品进行测试装箱 |
||
|
类名 |
AutoCarryStrip |
协作类及关系描述 |
|
职责 |
1. Product:产品 |
|
|
负责运送产品,当达到最大承载量时通知生产机器人停止生产,在承载量为0时通知测试机器人停止测试。 |
||
可以看出,我们需要四个类来实现我们的这个自动化场景。如下:
/**2
* 3
*/4
package patterns.producerConsumer;5

6
import java.util.Random;7

8
/**9
* producer<code>Producer</code> product a integer on IntTable until integer10
* count more than MaxCount.11
* 12
* @author Jackie Xie13
* 14
*/15
public class Producer extends Thread {16

17
private String name;18
private AutoCarryStrip table;19
private int totalCount =0;20

21
public Producer(String name, AutoCarryStrip table) {22
// TODO Auto-generated constructor stub23
this.name = name;24
this.table = table;25
}26

27
@Override28
public void run() {29
// TODO Auto-generated method stub30
while (true) {31
try {32
Thread.sleep((long)(Math.random()*3000));33
Thread.yield();34
Product p = new Product(this.name);35
System.out.println(this.name +" produced " + (++this.totalCount) );36
table.produce(p); 37
} catch (Exception e) {38
// TODO: handle exception39
e.printStackTrace();40
}41
}42
}43

44
}45

其实,通过以上代码,个人感觉这个模式其实就是给Guarded Suspension加了一个双重的守护,专门用来守护边界。


浙公网安备 33010602011771号