生产者消费者问题

原创 2015年07月09日 16:59:46


最近在学习线程同步问题,接触了生产者和消费者问题:

生产者生产产品、消费者消费产品,两者同时进行,怎么样实现两者的线程同步?

1.此问题中首先要搞清楚问题中有哪两个线程(生产者和消费者)

2.线程同步有什么必要性(现实生活中的实例)

3.线程之间的关系(线程之间应该有个产品的缓冲区来形成两个线程之间的关系)

4.两个线程共享同一个缓冲区

5.缓冲区满,生产者等待。缓冲区空,消费者等待

public class ProducerConsumer {
	public static void main(String[] args) {
		Store s = new Store();
		Producer p = new Producer(s);
		Producer p1 = new Producer(s);
		//Producer p2 = new Producer(s);

		Consumer su = new Consumer(s);
		//Consumer su1 = new Consumer(s);
		//Consumer su2 = new Consumer(s);

		new Thread(p).start();
		new Thread(p1).start();
		//new Thread(p2).start();
		new Thread(su).start();
		//new Thread(su1).start();
		// Thread(su2).start();
	}
}
class Product{//
	int id;
	Product(int id){
		this.id = id;
	}
	public String toString(){
		return "Product:"+id;
	}
}
class Producer implements Runnable{//
	Store s = null;
	Producer(Store s){
		this.s = s;
	}
	public void run(){
		for(int i = 0;i<10;i++){
			Product p = new Product(i);
			s.put(p);
			System.out.println("生产:"+p);
		}
	}
}
class Consumer implements Runnable{//
	Store s = null;
	Consumer(Store s){
		this.s = s;
	}
	public void run(){
		for(int i = 0;i<10;i++){
			Product p = s.get();
			System.out.println("消费:"+p);
		}
	}
}
class Store{//
	static Product[] p = new Product[10];
	static int index = 0;//
	public synchronized void put(Product pro){//
		if(index == p.length){
			try{
				this.wait();
			}
			catch (InterruptedException e)
			{
				e.printStackTrace();
			}
		}
		this.notifyAll();
		p[index] = pro;
		index++;
	}

	public synchronized Product get(){//
		if(index == 0){
			try{
				this.wait();
			}
			catch (InterruptedException e)
			{
				e.printStackTrace();
			}
		}
		this.notifyAll();
		index--;
		return p[index];
		
	}
}


相关文章推荐

一起talk C栗子吧(第一百零五回:C语言实例--生产者与消费者问题一)

各位看官们,大家好,上一回中咱们说的是进程知识体系图的例子,并且画了一张知识体系图。这一回咱们说的例子是:生产者与消费者问题。闲话休提,言归正转。让我们一起talk C栗子吧!...
  • talk_8
  • talk_8
  • 2016年01月17日 16:29
  • 1353

生产者消费者问题vc6源码

  • 2014年07月11日 08:42
  • 2.27MB
  • 下载

C例子:生产者与消费者问题

  • 2016年01月17日 22:13
  • 6KB
  • 下载

分别在windows和linux下用信号量解决生产者消费者问题

用信号量解决生产者消费者问题                                       实验目的   通过实验,掌握Windows和Linux环境下互斥锁和信号量的实现 方法...
  • yxq_fxd
  • yxq_fxd
  • 2016年05月15日 16:53
  • 562

windows实习2 生产者消费者问题

  • 2013年12月09日 19:48
  • 17KB
  • 下载

生产者/消费者问题的多种Java实现方式

生产者/消费者问题的多种Java实现方式   实质上,很多后台服务程序并发控制的基本原理都可以归纳为生产者/消费者模式,而这是恰恰是在本科操作系统课堂上老师反复讲解,而我们却视而不见不以为然的。在博文...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:生产者消费者问题
举报原因:
原因补充:

(最多只允许输入30个字)