【操作系统进程同步】自行车生产线

2024-03-05 19:30

本文主要是介绍【操作系统进程同步】自行车生产线,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题

设自行车生产线上有一只箱子, 其中有N个位置(N≥3), 每个位置可存放一个车架或一个车轮; 又设有三个工人, 其活动分别为:

伪代码

semphore maxFrameNum=N-2,maxWheelNum=N-1,frame=0,wheel=0,empty=N,mutex=1;worker1(){do{P(maxFrameNum);加工一个车架();P(emptyNum);		P(mutex);车架放入箱子中();V(mutex);V(frame);}while(true)
}worker2(){do{P(maxWheelNum);加工一个车轮();P(emptyNum);P(mutex);车轮放入箱子中();V(mutex);V(wheel);}while(true)
}worker3(){do{P(frame);P(mutex);从箱子中取一车架;V(mutex);V(maxFrameNum);V(empty);P(wheel);P(mutex);从箱子中取一车轮子;V(mutex);V(maxWheelNum);V(empty);P(wheel);P(mutex);从箱子中取一车轮子;V(mutex);V(maxWheelNum);V(empty);组装一辆车();		}while(true)
}

Python模拟

import random
import threading
import timeN = 3
maxFrameNum = N - 2
maxWheelNum = N - 1
frame = 0
wheel = 0
empty = N
mutex = 1def refresh(name):if name == 'maxFrameNum':return maxFrameNumelif name == 'maxWheelNum':return maxWheelNumelif name == 'frame':return frameelif name == 'wheel':return wheelelif name == 'empty':return emptyelif name == 'mutex':return mutexdef p(id, item, name):print('【woker%s】need a  %s(%d)' % (id, name, item))while item <= 0:print('【woker%s】is waiting for %s' % (id, name))time.sleep(random.random())item = refresh(name)global maxWheelNumglobal maxFrameNumglobal wheelglobal emptyglobal mutexglobal frameif name == 'maxFrameNum':maxFrameNum -= 1elif name == 'maxWheelNum':maxWheelNum -= 1elif name == 'frame':frame -= 1elif name == 'wheel':wheel -= 1elif name == 'empty':empty -= 1elif name == 'mutex':mutex -= 1def v(id, item, name):global maxWheelNumglobal maxFrameNumglobal wheelglobal emptyglobal mutexglobal frameif name == 'maxFrameNum':maxFrameNum += 1elif name == 'maxWheelNum':maxWheelNum += 1elif name == 'frame':frame += 1elif name == 'wheel':wheel += 1elif name == 'empty':empty += 1elif name == 'mutex':mutex += 1print('【woker%s】release  %s' % (id, name))def printMsg():print('maxFrameNum:%s,maxWheelNum:%s,frame:%s,wheel:%s,empty:%s' % (maxFrameNum, maxWheelNum, frame, wheel, empty))def woker1():while True:time.sleep(random.random() * 4)p(1, maxFrameNum, 'maxFrameNum')print('【woker1】is making a frame')p(1, empty, 'empty')p(1, mutex, 'mutex')print('【woker1】is putting a frame into the box')v(1, mutex, 'mutex')v(1, frame, 'frame')printMsg()def woker2():while True:time.sleep(random.random() * 2)p(2, maxWheelNum, 'maxWheelNum')print('【woker2】is making a wheel')p(2, empty, 'empty')p(2, mutex, 'mutex')print('【woker2】is putting a wheel into the box')v(2, mutex, 'mutex')v(2, wheel, 'wheel')printMsg()def woker3():while True:time.sleep(random.random() * 4)p(3, frame, 'frame')p(3, mutex, 'mutex')print('【woker3】is getting a frame from the box')v(3, mutex, 'mutex')v(3, maxFrameNum, 'maxFrameNum')v(3, empty, 'empty')printMsg()p(3, wheel, 'wheel')p(3, mutex, 'mutex')print('【woker3】is getting a wheel from the box')v(3, mutex, 'mutex')v(3, maxWheelNum, 'maxWheelNum')v(3, empty, 'empty')printMsg()p(3, wheel, 'wheel')p(3, mutex, 'mutex')print('【woker3】is getting a wheel from the box')v(3, mutex, 'mutex')v(3, maxWheelNum, 'maxWheelNum')v(3, empty, 'empty')printMsg()print('【woker3】is making a car')if __name__ == '__main__':w1 = threading.Thread(target=woker1)w2 = threading.Thread(target=woker2)w3 = threading.Thread(target=woker3)w1.start()w2.start()w3.start()

最终效果

 

 总结

1. PV操作中需要修改全局变量,而Python修改全局变量需要使用关键字global声明一下,若使用C++写会比较方便,直接使用指针就可以修改全局变量了。

2. maxFrameNum初始值设置为N-1也可以保证不产生死锁。

3. 老师的PPT中没有使用mutex变量来访问临界资源(箱子),个人感觉有必要加上mutex。(若有不同想法,欢迎留言讨论~

这篇关于【操作系统进程同步】自行车生产线的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/777567

相关文章

Linux操作系统 初识

在认识操作系统之前,我们首先来了解一下计算机的发展: 计算机的发展 世界上第一台计算机名叫埃尼阿克,诞生在1945年2月14日,用于军事用途。 后来因为计算机的优势和潜力巨大,计算机开始飞速发展,并产生了一个当时一直有效的定律:摩尔定律--当价格不变时,集成电路上可容纳的元器件的数目,约每隔18-24个月便会增加一倍,性能也将提升一倍。 那么相应的,计算机就会变得越来越快,越来越小型化。

1、简述linux操作系统启动流程

1、简述linux操作系统启动流程 启动第一步--加载BIOS 当你打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始就找到它。这是因为BIOS中包含了CPU的相关信息、设备启动顺序信息、硬盘信息、内存信息、时钟信息、PnP特性等等。开机时将ROM中的指令映射到RAM的低地址空间,CPU读取到这些指令,硬件的健康状况进行检查,按照BIOS中设置的启

操作系统是怎么为不同的程序分配所需的内存空间的

操作系统为不同的程序分配内存空间的过程涉及多个关键步骤,确保每个程序都有其所需的内存资源,同时避免程序之间的冲突。以下是操作系统如何为程序分配内存空间的详细过程: 1. 内存管理的基础概念 虚拟内存:现代操作系统使用虚拟内存机制来为程序提供隔离的内存空间。每个程序运行在其独立的虚拟地址空间中,这使得程序间的内存互不干扰。物理内存:实际的 RAM(随机存取存储器),由操作系统和硬件共同管理。虚拟

操作系统安全保护

操作系统安全概述 概念:满足安全策略要求,具有响应安全机制及安全功符合特定安全标准,在一定约束条件下 能抵御常见网络安全威胁,保障自身安全运行及资源安全 安全等级:根据安全功能和安全保障要求分为 用户自主保护级  系统审计保护级 安全标记保护级 结构化保护级 访问验证保护级 操作系统作用: 负责计算系统的资源管理、支撑和控制各种应用程序运行,为用户提供计算机系统管理接口 是构成网络信息

Linux操作系统命令集(一)

最近开了操作系统的课,弄着虚拟机的linux系统命令学学 文件和目录操作命令: ls:列出目录内容 示例:ls -l 以长格式列出目录内容cd:切换目录 示例:cd /home/user 切换到 /home/user 目录mkdir:创建目录 示例:mkdir new_directory 创建名为 new_directory 的目录rmdir:删除空目录touch:创建空文件或更新文件的时间戳

操作系统分页式存储管理

每次输入地址后,计算出页号,若页号越界,则给出错误提示。否则依次调用FIFO和LRU算法,这里值得注意的是,由于我们的FIFO算法先于LRU算法被调用,那么当在处理FIFO算法时,我们暂且不将位视图相应位置做变化,留到处理LRU算法再做处理。 对于FIFO、LRU算法的缺页,我们分两种情况考虑,第一种是模拟栈内还有空间,那么直接将其入栈。第二种是模拟栈内无空间,要发生置换。发生置换时把模拟栈最底

linux定时监听ssh服务是否启动-------麒麟操作系统永久关闭swap

linux监听ssh服务是否启动 1、监听脚本2、定时任务3、麒麟操作系统,永久关闭swap 1、监听脚本 #在/usr/local/bin目录下新建脚本文件 cd /usr/local/bintouch check_sshd.sh#给可执行权限chmod +x /usr/local/bin/check_sshd.sh 脚本内容如下: #!/bin/bashs

【银河麒麟高级服务器操作系统实例】虚拟化平台系统服务中断现象分析及处理建议

服务器环境以及配置 【机型】虚机 处理器: Kunpeng-920 内存: 40G 【内核版本】 4.19.90-23.8.v2101.ky10.aarch64 【OS镜像版本】 银河麒麟操作系统 Kylin-Server-10-SP1-Release-Build20-20210518-arm64 【第三方软件】 智能运维系统、mysql数据集群 现象描述 环境描

VMware17 虚拟机下载以及 CentOS8 操作系统安装配置 一条龙全教程

目录 一、安装 vmware workstation 虚拟机  二、安装 CentOS8 操作系统 三、安装 FinalShell 远程连接 一、安装 vmware workstation 虚拟机     安装中...(耐心等待)  到此安装完成,点击启动运行  激活码如下:  MC60H-DWHD5-H80U9-6V85M-8280D

操作系统之虚拟机

虚拟机(Virtual Machine, VM)是一种通过虚拟化技术将一台物理计算机虚拟化为多个独立的虚拟计算机的技术。每个虚拟机都可以运行自己的操作系统,仿佛它们是独立的物理计算机。虚拟机的引入大大提高了计算资源的利用率,并提供了更大的灵活性。 虚拟机的定义 虚拟机是通过虚拟化技术在一台物理计算机上创建的多个虚拟计算环境。每个虚拟环境(虚拟机)都可以运行一个独立的操作系统和应用程序,仿