- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
多道程序缓冲区协调操作操作系统报告
苏州科技学院天平学院
操作系统课程设计 报告
--多道程序缓冲区协调操作 指导教师 陆卫忠
2012年7月 4 日
任务分配情况
姓名 承担的任务 金志献 编写主函数 编译执行程序并修改 刘志愿 协助修改程序 编写报告
多道程序缓冲区协调操作目的(1)了解提出信号量的背景 (2)掌握信号量的基本概念及 PV 操作的原理 (3)进一步熟悉信号量解决的经典问题 (4)利用信号量的原理实现不同操作系统下同步互斥问题主要完成的任务有10个P操作要不断循环地向Buffer送数据,有一个Move操作要不断地将Buffer的数据取到Buffer,有20个GET操作要不断地从Buff中取数据。Buffer的容量是10,Buff的容量是20, P、 M、 G每次操作一个数据,为了在操作的过程中要保证数据不丢失,每个Buffer每次只能接受一个P或一个Move或一个Get,多个操作不能同时操作同一B。设计一个多道程序完成上述操作。
试用P、V原语协调P、 M、G的操作,并说明每个信号量的含义、初值和值的范围。
使用的开发工具解决的主要问题需求分析 利用信号量实现缓冲区管理临界区协调问题。解决由于进程线程共享内存而出 现的与时间有关的错误。为解决多进程线程同步与互斥问题,让两个或多个多道进程线程通过特殊的变量展开交互。进程是正在运行的程序实体,并且包括这个运行的程序中占据的所有系统资源进程的同步与互斥是指进程在推进时的相互制约关系进程同步:它主要源于进程合作,是进程间共同完成一项任务时直接发生的关系。进程互斥:它主要源于资源共享,是进程之间的间接制约关系。如下图所示,有10个PUT操作要不断循环地向Buffer1送数据,有一个Move操作要不断地将Buffer1的数据取到Buffer2,有20个GET操作要不断地从Buff2中取数据。BUFF1是10,BUFF2的容量是20, PUT、 MOVE、 GET每次操作一个数据,为了在操作的过程中要保证数据不丢失,每个Buffer每次只能接受一个PUT或一个Move或一个Get,多个操作不能同时操作同一BUFFER。设计一个多道程序完成上述操作。
试用P、V原语协调PUT、 MOVE、GET的操作,并说明每个信号量的含义、初值和值的范围。
四.详细设计
4.1线程规划
我们创建三类线程:
(1)PUT线程(往BUFFER1里放数据,相当于生产者)。
(2)MOVE线程(从BUFFER1里取数据并放到BUFFER2里,相当于搬运者)。
(3)GET线程(从BUFFER2里取数据,相当于消费者)。
每类线程可由用户自行设定线程的个数。
4.2信号量的设置
需要设置六个信号量full1 empty1 buff1 full2 empty2 buff2。各信号量含义及初值如下:
full1表示buffer1是否有数据,初值为0;
empty1表示buffer1是否有空间,初值为m;
buff1表示buffer1是否可操作,初值为1;
full2表示buffer2是否有数据,初值为0;
empty2表示buffer2是否有空间,初值为n;
buff2表示buffer2是否可操作,初值为1。
五.编码设计
1.开发环境为Linux,我们在进入RedHat Linux 后输入startx进入图形界面,在任务菜单里可以寻找终端,即可进行代码编写与执行。
2.程序源代码如下
/**************** 定义头文件 ****************/
#include stdio.h
#include stdlib.h
#include unistd.h
#include pthread.h
#include errno.h
#include sys/ipc.h
#include semaphore.h
/**************** 定义头变量 ****************/
sem_t iFull,iEmpty;
sem_t oFull,oEmpty;
int iIn=0,iOut=0,oIn=0,oOut=0;
sem_t sem1,sem2;
char inBuffer[10];
char outBuffer[20];
int data1,data2,data3;
void put(void *arg);
void move(void *arg);
void get(void *arg);
/**************** mian函数 ****************/
main(int argc, char *argv[])
{
int i,j;
int *task1[10];
int *task2[20];
pthread_t id1[
您可能关注的文档
最近下载
- rcwl-9610低成本分体开放式超声波测距芯片.pdf VIP
- (高清版)DB33∕T 2110.5-2018 实验动物 长爪沙鼠 第5部分:配合饲料营养成分.pdf VIP
- 大学物理(山东联盟)智慧树知到期末考试答案章节答案2024年青岛科技大学.docx VIP
- 《个人所得税培训》课件.ppt VIP
- 实验室生物安全管理体系内审表(2011).docx VIP
- 价值流分析.ppt.ppt VIP
- 小学三年级数学应用题大全(夺冠系列).docx VIP
- 一种SGH换热器以及垃圾发电系统.pdf VIP
- 考研英语-常用词组大全4249个.pdf VIP
- 2025年幼儿园基孔肯雅热防控工作方案.docx
文档评论(0)