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

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系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

五大特性引领创新! 深度操作系统 deepin 25 Preview预览版发布

《五大特性引领创新!深度操作系统deepin25Preview预览版发布》今日,深度操作系统正式推出deepin25Preview版本,该版本集成了五大核心特性:磐石系统、全新DDE、Tr... 深度操作系统今日发布了 deepin 25 Preview,新版本囊括五大特性:磐石系统、全新 DDE、Tree

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