首页 > 其他 > 详细

生产者消费者

时间:2017-07-17 19:17:57      阅读:216      评论:0      收藏:0      [点我收藏+]

package com.charles.algorithm;

public class ConsumerProducer {
/**
* @desc: single object implements producer and consumer by array
*/
final private int SIZE = 10;
private int head = 0, tag = 0, count = 0;
private Object[] items = new Object[SIZE];

public static void main(String[] args) {

// define 5 producers
ConsumerProducer conducer = new ConsumerProducer();
for (int i = 0; i < 5; i++) {
new Thread(new Runnable() {
@Override
public void run() {
while (true) {
conducer.produce();
}
}
}).start();
}
// define 3 consumers
for (int i = 0; i < 3; i++) {
new Thread(new Runnable() {
@Override
public void run() {
while (true) {
conducer.consume();
}
}
}).start();
}
}

public synchronized void produce() {
while (isFull()) {
try {
System.out.println(Thread.currentThread().getName() + " 已满:" + count +" 等代销费者");
this.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}

items[tag++] = true;
count++;
if (tag == items.length) {
tag = 0;
}
this.notifyAll();
try {
System.out.println(Thread.currentThread().getName() + " 生产一个,剩余" + count);
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

public synchronized void consume() {
while (isEmpty()) {
try {
System.out.println(Thread.currentThread().getName() + " 已空:" + count+" 等代生产者");
this.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}

items[head] = null;
head++;
count--;
if (head == items.length) {
head = 0;
}
this.notifyAll();
try {
System.out.println(Thread.currentThread().getName() + " 消费一个,还有" + count);
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

private boolean isFull() {
return count == items.length;
}

private boolean isEmpty() {
return 0 == count;
}
}

生产者消费者

原文:http://www.cnblogs.com/julygift/p/7197047.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!