操作系统课程设计--模拟生产者消费者问题

本文通过Java实现了一个经典的生产者消费者问题案例。该案例利用多线程技术模拟了生产者和消费者之间的交互过程,其中生产者不断生产产品并放入有界缓冲区,而消费者则从该缓冲区获取产品进行消费。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

操作系统课程设计--模拟生产者消费者问题

问题描述

一组生产者向一组消费者提供消息,它们共享一个有界缓冲区n,生产者向其中投放消息,消费者从中取得消息

PV原语描述

void main() {
	producer();
	customer();
}
void producer() {
	while(生产未完成) {
		生产一个产品
		p(empty)//empty 表示仓库还可以存放产品的空位
		p(mutex)//对仓库的互斥访问
        向仓库中存放一个产品
        v(mutex)
        v(full)
	}
}
void customer() {
	while(还要继续消费) {
		p(full)//full表示仓库内现存产品数
		p(mutex)
        从仓库中取出一个产品
        v(mutex)
        v(empty)
        消费产品
	}
}

代码描述

package produce_customer3;

public class produce_customer {

	public static void main(String[] args) {
		House house=new House();
		producer p=new producer(house);
		customer c=new customer(house);
		//System.out.println("Hello world");
		new Thread(p).start();
		new Thread(c).start();
	}
}
//产品类
class Product {
	int id;
	Product(int id){
		this.id=id;
	}
	public String toString() {
		return "" +id;
	}
}
//仓库类
class House {
	Product[] proArry=new Product[5];//仓库容量
	int count=0;//仓库现存产品数量
	boolean useIndex=false;//标志此时是否有生产者/消费者正在使用仓库
	public synchronized void housein(Product product) throws InterruptedException {
		
		if(count==5) {
			this.wait();
		}
		
		else if(useIndex) {
			this.wait();
		}
		useIndex=true;
		 
		proArry[count]=product;
		count++;
		useIndex=false;
		this.notify();
		System.out.println("生产第"+product+"件,现在仓库有"+count+"件");
	}
	
   public synchronized Product houseout() throws InterruptedException {
		if(count==0) {
			this.wait();
		}
		
		else if(useIndex) {
			this.wait();
		}
		useIndex=true;
		 
		count--;
		Product product=proArry[count];
		useIndex=false;
		this.notify();
		System.out.println("消费第"+product+"件,现在仓库有"+count+"件");
		return product;
	}
}
//生产者
class producer implements Runnable{
	House house=null; 
	producer(House house){
		this.house=house;
	}
	public  void run() {
		//System.out.println(id+"开始运行");
		for(int i=0;i<10;i++) {
			try {
				Product product=new Product(i+1);
				//System.out.println("生产者"+"开始运行");
				house.housein(product);
				Thread.sleep(50);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		}
		
	}
}
//消费者
class customer implements Runnable{
	House house=null; 
	customer(House house){
		this.house=house;
	}
	public void run() {
		//System.out.println(id+"开始运行");
		for(int i=0;i<10;i++) {
			try {
				//System.out.println("消费者"+i+"开始运行");
				house.houseout();
				Thread.sleep(500);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		}
		
	}
}


效果截图

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值