生产者-消费者问题
1.操作系统的概念与功能2.操作系统的特征3.操作系统的发展与分类4.操作系统的运行机制5.中断和异常6.系统调用7.计算机系统体系结构8.操作系统引导 (Boot)9.虚拟机10.进程的概念、组成、特征11.进程的状态与转换、进程的组织12.进程控制13.进程通信14.线程的概念、作用和属性15.线程的实现方式和多线程模型16.线程的状态与转换、组织与控制17.调度的概念与层次18.进程调度的时机、方式、切换与过程19.闲逛进程20.调度算法的评价指标21.调度算法22.调度算法(一)23.调度算法(二)24.调度算法(三)25.进程同步与进程互斥26.进程互斥的软件实现方法27.进程互斥的硬件实现方法28.互斥锁29.信号量机制30.信号量实现进程互斥、同步、前驱关系
31.生产者-消费者问题
32.多生产者-多消费者问题33.吸烟者问题34.读者-写者问题35.哲学家进餐问题36.管程37.死锁38.死锁的处理策略39.(一)预防死锁40.(二)避免死锁41.(三)死锁检测和解除42.内存的基础知识43.内存管理的概念44.覆盖与交换45.连续分配管理方式46.动态分区分配算法47.基本分页存储管理的基本概念48.基本地址变换机构49.具有快表的地址变换机构50.两级页表51.基本分段存储管理方式52.段页式管理方式53.虚拟内存的基本概念54.请求分页管理方式55.页面置换算法56.页面分配策略57.内存映射文件58.初识文件管理59.文件的逻辑结构60.文件目录61.文件的物理结构(文件分配方式)62.逻辑结构与物理结构63.文件存储空间管理64.文件的基本操作65.文件共享66.文件保护67.文件系统的层次结构68.文件系统的全局结构(布局)69.虚拟文件系统&文件系统挂载(安装)70.IO设备的概念和分类71.IO控制器72.IO控制方式73.IO软件层次结构74.IO应用程序接口&设备驱动程序接口75.IO核心子系统76.假脱机技术(SPOOLing技术)77.设备的分配与回收78.缓冲区管理79.磁盘的结构80.磁盘调度算法81.减少延迟时间的方法82.磁盘的管理83.固态硬盘生产者-消费者问题
一、问题背景及分析
- 系统中有一组生产者进程和一组消费者进程,生产者进程每次生产一个产品放入缓冲区,消费者进程每次从缓冲区中取出一个产品并使用。(注:这里的“产品”理解为某种数据)
- 生产者、消费者共享一个初始为空、大小为 n 的缓冲区。
- 只有缓冲区没满时,生产者才能把产品放入缓冲区,否则必须等待。
- 只有缓冲区没空时,消费者才能从中取出产品,否则必须等待,
- 缓冲区是临界资源,各进程必须互斥地访问。(互斥关系)
二、问题实现
理解补充:
- 生产者生产了一个产品,现在要把它放入缓冲区,所以要先 P 一下 empty 看看有没有空闲缓冲区可以装入刚生产的产品;产品的总数量增加,这时候同时要 V 一下释放一个 full 资源。
- 在同一个进程中互斥是保证当前只有一个生产者进程进入临界区,为了防止两个生产者进程同时往缓冲区内同一块地方写入数据。
- 互斥表示这两个进程不能同时对缓冲区进行操作,而同步表示这两个进程是在同一段时间内一个生产一个消费。
- P(empty) 在 P(mutex) 之前是因为要先检测缓冲区是否有人使用(先检测是否有空闲缓冲区),再执行释放资源(占用缓冲区)(进厕所前先看看有没有坑位,不然占用了厕所但得不到坑位,可能导致死锁)。
三、问题思考
(一)能否改变相邻 P 或相邻 V 操作的顺序
P 不能。实现互斥的 P 操作一定要在实现同步的 P 操作之后,否则会导致死锁。
V 可以。V 操作不会导致进程阻塞。
(二)生产者的生产过程和消费者的消费过程能否放入P、V操作之间
逻辑上可以,但会导致临界区代码变长,即导致一个进程对临界区的上锁时间增长,不利于各进程交替使用临界区资源,上锁的范围应尽量小。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现