首先建了一个简单的Product
类,用来表示生产和消费的产品
package com.spring.boot.entity;
public class Product {
private String name;
public Product(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
主函数里我设定了两类线程,并且这里选择用普通的ArrayDeque
来实现Queue
,更简单的方式是直接用Java 中的BlockingQueue
来实现。
BlockingQueue
是阻塞队列,它有一系列的方法可以让线程实现自动阻塞,常用的。这里为了更好的理解并发协同的这个过程,我们先自己处理。
package com.spring.boot.entity;
import java.util.ArrayDeque;
import java.util.Queue;
public class ProducerAndConsumer {
public static void main(String[] args) {
Queue<Product> queue = new ArrayDeque<>();
for (int i = 0; i < 100; i++) {
new Thread(new Producer(queue, 100)).start();
new Thread(new Consumer(queue, 100)).start();
}
}
}
然后就是Producer
和Consumer
了。
package com.spring.boot.entity;
import java.util.Queue;
import java.util.Random;
public class Producer implements Runnable{
private Queue<Product> queue;
private int maxCapacity;
public Producer(Queue queue, int maxCapacity) {
this.queue = queue;
this.maxCapacity = maxCapacity;
}
@Override
public void run() {
while(true) {
synchronized (queue) {