IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 操作系统课程设计--模拟生产者消费者问题 -> 正文阅读

[Java知识库]操作系统课程设计--模拟生产者消费者问题

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

问题描述

一组生产者向一组消费者提供消息,它们共享一个有界缓冲区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();
		}
		}
		
	}
}


效果截图

在这里插入图片描述

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-01-17 11:22:16  更:2022-01-17 11:23:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:29:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码