【此后无良辰】实验5 进程的同步

2024-01-10 01:20

本文主要是介绍【此后无良辰】实验5 进程的同步,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实验目的

掌握使用信号量编程解决进程/线程同步互斥问题的方法;了解操作系统进程/线程同步的原理。

实验内容与记录

3.2 该实验给出的是单人单缓-单人多缓-多人单缓-多人多缓中的哪一个问题实现?程序通过什么方式实现了生产者比消费者快的同步过程?在这种情况下,为什么生产者在生产了13号产品后还会阻塞?
(1) 单人多缓
(2) 实现方式:
消费者在前十四个每2000ms询问消费一次,后十四个每隔100ms询问消费一次。
在这里插入图片描述

生产者每隔500ms产生。
在这里插入图片描述

因此可以保证在前十四个消费者时,生产者的生产速度大于消费者的消费速度,即实现了生产者比消费者快的同步进度。
(3)阻塞原因:
通过计算可知,当生产者生产了第13号 产品(总共十四个产品)时,消费者消费了4 个产品,此时缓冲池中的 10 个缓冲区均被占用,即产生了阻塞。等消费者从缓冲池中再次消费产品,使得缓冲区产生空时,生产者才会被唤醒并继续生产 13号产品。
3.3 根据调试过程中的学习和思考,绘制ps/semaphore.c文件内PsWaitForSemaphore和PsReleaseSemaphore函数的流程图,并说明其实现原子操作的方法。
PsWaitForSemaphore的代码截图:
在这里插入图片描述

根据代码截图绘制出PsWaitForSemaphore函数的流程图:
在这里插入图片描述

PsReleaseSemaphore代码截图:

在这里插入图片描述

根据代码截图绘制出PsReleaseSemaphore函数的流程图:
在这里插入图片描述

3.4 修改以上两个函数,使其可以支持等待超时唤醒功能和批量释放功能。截图说明修改成功可以完成相应功能,思考并解释这段代码为什么可以实现这样的功能。(后面已给出代码,请自己输入并调试)
(1)使得修改完毕的EOS Kernel项目生成的SDK文件夹覆盖原有的EOS APP项目的SDK文件夹
修改的EOS Kernel:
在这里插入图片描述
在这里插入图片描述

运行调试如图:批量释放
在这里插入图片描述
在这里插入图片描述

(2)修改Producer和Consumer函数以实现超时唤醒
修改代码截图:
在这里插入图片描述
在这里插入图片描述

运行调试如图:超时唤醒 + 批量释放
在这里插入图片描述
在这里插入图片描述

实验思考题

尝试创建多个生产者线程和多个消费者线程进行同步,注意临界资源也会发生变化。输出结果展示不同生产者和消费者的行为,以及临界资源的变化,进行截图。(有阻塞情况、没有阻塞情况)

(1) 定义9个生产者,8个消费者
在这里插入图片描述

(2) 运行结果截图

在这里插入图片描述

望能对诸君有所帮助,切忌直接抄袭(觉得有用记得点赞呀~)

这篇关于【此后无良辰】实验5 进程的同步的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

STM32(十一):ADC数模转换器实验

AD单通道: 1.RCC开启GPIO和ADC时钟。配置ADCCLK分频器。 2.配置GPIO,把GPIO配置成模拟输入的模式。 3.配置多路开关,把左面通道接入到右面规则组列表里。 4.配置ADC转换器, 包括AD转换器和AD数据寄存器。单次转换,连续转换;扫描、非扫描;有几个通道,触发源是什么,数据对齐是左对齐还是右对齐。 5.ADC_CMD 开启ADC。 void RCC_AD

java 进程 返回值

实现 Callable 接口 与 Runnable 相比,Callable 可以有返回值,返回值通过 FutureTask 进行封装。 public class MyCallable implements Callable<Integer> {public Integer call() {return 123;}} public static void main(String[] args

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(

HNU-2023电路与电子学-实验3

写在前面: 一、实验目的 1.了解简易模型机的内部结构和工作原理。 2.分析模型机的功能,设计 8 重 3-1 多路复用器。 3.分析模型机的功能,设计 8 重 2-1 多路复用器。 4.分析模型机的工作原理,设计模型机控制信号产生逻辑。 二、实验内容 1.用 VERILOG 语言设计模型机的 8 重 3-1 多路复用器; 2.用 VERILOG 语言设计模型机的 8 重 2-1 多

Golang进程权限调度包runtime

关于 runtime 包几个方法: Gosched:让当前线程让出 cpu 以让其它线程运行,它不会挂起当前线程,因此当前线程未来会继续执行GOMAXPROCS:设置最大的可同时使用的 CPU 核数Goexit:退出当前 goroutine(但是defer语句会照常执行)NumGoroutine:返回正在执行和排队的任务总数GOOS:目标操作系统NumCPU:返回当前系统的 CPU 核数量 p

MySQL主从同步延迟原理及解决方案

概述 MySQL的主从同步是一个很成熟的架构,优点为: ①在从服务器可以执行查询工作(即我们常说的读功能),降低主服务器压力; ②在从主服务器进行备份,避免备份期间影响主服务器服务; ③当主服务器出现问题时,可以切换到从服务器。 相信大家对于这些好处已经非常了解了,在项目的部署中也采用这种方案。但是MySQL的主从同步一直有从库延迟的问题,那么为什么会有这种问题。这种问题如何解决呢? MyS