- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验四:同步机构实验报告
学 院:
专业班级:
姓 名:
学 号:
一、实验内容:
模拟实现用同步机构避免发生进程执行时可能出现的与时间有关的错误。
二、实验目的:
进程是程序在一个数据集合上运行的过程,进程是并发执行的,也即系统中的多个进程轮流地占用处理器运行。
我们把若干个进程都能进行访问和修改的那些变量称为公共变量。由于进程是并发地执行的,所以,如果对进程访问公共变量不加限制,那么就会产生“与时间有关”的错误,即进程执行后所得到的结果与访问公共变量的时间有关。为了防止这类错误,系统必须要用同步机构来控制进程对公共变量的访问。一般说,同步机构是由若干条原语——同步原语——所组成。本实验要求学生模拟PV操作同步机构的实现,模拟进程的并发执行,了解进程并发执行时同步机构的作用。
三、实验题目:
模拟PV操作同步机构,且用PV操作解决生产者——消费者问题。
四、此次用到的数据结构知识如下:
typedef struct Pcb{
char name[10]; //进程名
char state[10]; //运行状态
char reason[10]; //若阻塞,其原因
int breakp; //断点保护
struct Pcb *next; //阻塞时的顺序
进程名 状态 等待原因 断点 后继进程 }Pcb,*link;
进程控制块结构
定义两个进程: link p1;//生产者进程,link c1;//消费者进程。pc程序计数器和
link ready; 就绪队列,link b_s1; s1阻塞队列,link b_s2; s2阻塞队列。
五、实验源代码:
分为四个头文件。
1、a.h头文件代码如下:
#includestring.h
#includectype.h
#includemalloc.h /* malloc()等 */
#includelimits.h /* INT_MAX等 */
#includestdio.h /* EOF(=^Z或F6),NULL */
#includestdlib.h /* atoi() */
#includeio.h /* eof() */
#includemath.h /* floor(),ceil(),abs() */
#includeprocess.h /* exit() */
#include iostream
using namespace std;
#include time.h
#define BUF 10 //缓存的大小
#define MAX 20 //最大可以输入的字符
2、b.h头文件代码如下:
//数据结构的定义和全局变量
typedef struct Pcb{
char name[10]; //进程名
char state[10]; //运行状态
char reason[10]; //若阻塞,其原因
int breakp; //断点保护
struct Pcb *next; //阻塞时的顺序
}Pcb,*link;
int s1,s2; //信号量
link p1;//生产者进程
link c1;//消费者进程
char str[MAX]; //输入的字符串
char buffer[BUF]; //缓冲池
int len; //输入长度
int sp=0; //string的指针
int in=0; //生产者指针
int out=0; //消费者指针
char temp; //供打印的临时产品
char rec_p[MAX];//生产记录
int rp1=0;//生产记录指针
char rec_c[MAX];//消费记录
int rp2=0;//消费记录指针
link ready; //就绪队列
link b_s1; //s1阻塞队列
link b_s2; //s2阻塞队列
int pc; //程序计数器
int count; //字符计数器
int con_cnt; //消费计数器
3、c.h头文件代码如下:
void init(); //初始化
void p(int s); //P操作
void v(int s); //V操作
void block(int s);//阻塞函数
void wakeup(int s);//唤醒函数
void control(); //处理机调度
void proce
您可能关注的文档
- 龙湖集团信息化及项目管理体系资料.ppt
- 龙潭裕都总部城简介资料.ppt
- 隆鑫花漾城高层定价建议(改)_1_资料.ppt
- 楼盘介绍-跑马地花园资料.ppt
- 楼宇智能化技术资料.ppt
- 卢彦启-实习报告3资料.doc
- 颅内压监测资料.ppt
- 鲁教版高中地理必修二第四单元第二节交通运输布局资料.ppt
- 鲁教版思品九年级《责任对于你我他》课件资料.ppt
- 录播教室系统方案书资料.doc
- 2025年无人机低空医疗物资投放社会效益报告.docx
- 2025年再生塑料行业包装回收利用产业链重构研究.docx
- 《AI眼镜周边产品市场机遇:2025年终端销售与需求增长洞察》.docx
- 2025年坚果加工行业深加工技术突破与市场拓展策略报告.docx
- 2025年通信芯片行业技术竞争与未来趋势报告.docx
- 《2025年生鲜电商配送冷链事故分析与预防措施》.docx
- 《商业航天融资新趋势2025民营卫星企业资本涌入估值分析市场动态》.docx
- 2025年能源绿色健康行业创新技术与市场应用报告.docx
- 2025年无人机低空医疗救援通信方案分析报告.docx
- 2025年烹饪机器人行业市场集中度分析报告.docx
最近下载
- 基于UbD理论的深度理解导向教学设计.docx VIP
- 青山湖科技城省科创基地单元控制性详细规划.pdf VIP
- 宇通资料.doc VIP
- 《放疗并发症及护理》课件.ppt VIP
- 牙膏生产线设备安全操作规程.docx VIP
- 课堂观察工具评分规则与目标分解-小组作业分享教学提纲.ppt VIP
- 《西藏自治区好住宅技术标准》DB54T 0527-2025(西藏标准).pdf
- 七上英语新人教版按课文内容填空 -挖空版每天早背晚默写.docx VIP
- 牛津译林版 必修第一册 Unit 4 Looking Good,Feeling Good Welcome to the unit & Reading课件(49张ppt)(含音频+视频).pptx VIP
- 2024年八上数学冀教课后习题答案.pdf VIP
原创力文档


文档评论(0)