ImageVerifierCode 换一换
格式:DOCX , 页数:7 ,大小:197.37KB ,
资源ID:17534842      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/17534842.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(北邮操作系统进程同步实验报告及源代码Word格式文档下载.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

北邮操作系统进程同步实验报告及源代码Word格式文档下载.docx

1、在这个程序里我设计了三个函数: Int main()是主函数,其中包含了缓冲区大小的设置,生产者消费者发出请求等容以及线程创建等容DWORD WINAPI producer(LPVOID lpPara)是生产者等待缓冲区的使用权并对缓冲区进行操作DWORD WINAPI consumer(LPVOID lpPara)是消费者等待缓冲区的使用权并对缓冲区进行操作 该程序模拟生产者消费者问题,首先要设置缓冲区的大小,输入请求资源的各个进程的信息以及请求时间,并且按照请求时间对各进程进行排序,创建线程,然后按序依次对缓冲区进行操作,详细设计见源代码。5、程序运行结果截图:只有生产者请求,没有消费者请

2、求,请求满足只有消费者请求,没有生产者请求,消费者的请求不成功:生产者请求大于消费者请求并且消费者请求在生产者放入产品之后:消费者请求多于生产者请求,只能满足部分消费者请求,不能满足全部:6、源代码:#include cstdlibcstringiostreamalgorithmwindows.husing namespace std;#define MAX_BUF 1000#define MAX_REQ 20 HANDLE mutex;HANDLE full;HANDLE empty; HANDLE threadMAX_REQ;DWORD pro_idMAX_REQ;DWORD con_id

3、MAX_REQ;struct request int type;/记录生产者消费者的类型 int seq; /记录请求次序 reqMAX_REQ;int buf_size;int req_size;int no;int bufferMAX_BUF;int in;int out;int result;bool cmp(request a,request b) return a.seqb.seq;DWORD WINAPI producer(LPVOID lpPara) WaitForSingleObject(full,INFINITE); WaitForSingleObject(mutex,INF

4、INITE); printf(生产者%d将第%d号产品放入缓冲区n,(int)lpPara,no); bufferin=no+; in=(in+1)%buf_size;成功放入缓冲区!nn,(int)lpPara); ReleaseMutex(mutex); ReleaseSemaphore(empty,1,NULL); return 0; DWORD WINAPI consumer(LPVOID lpPara) WaitForSingleObject(empty,INFINITE);消费者%d将第%d号产品从缓冲区取出n,(int)lpPara,bufferout); bufferout=0

5、;成功从缓冲区取出! out=(out+1)%buf_size; ReleaseSemaphore(full,1,NULL);int main() int i; int p=0; no = 1; in=out=0; memset(buffer, 0, sizeof(buffer);请设置缓冲区大小:); scanf(%d,&buf_size);请输入请求使用资源进程的个数:req_size); for(i=0;ireq_size;i+)请选择是消费者进程(0)还是生产者进程(1):reqi.type);请输入该进程的请求时间:reqi.seq); sort(req,req+req_size,c

6、mp); mutex=CreateMutex(NULL,FALSE,NULL); full=CreateSemaphore(NULL,buf_size,buf_size,NULL); empty=CreateSemaphore(NULL,0,buf_size,NULL);i+) if(reqi.type=0) threadi=CreateThread(NULL, 0, consumer, (LPVOID)i, 0, &con_idi); if(threadi=NULL) return -1;n消费者请求从缓冲区中取产品,请求时间为%dn,reqi.seq); if(reqi.type=1) t

7、hreadi=CreateThread(NULL,0,producer,(LPVOID)i,0,&pro_idi);n生产者请求往缓冲区中放产品,请求时间为%dn result = WaitForMultipleObjects(req_size, thread, TRUE, 500); if (result = WAIT_TIMEOUT)n请求不能被完全满足n elsen能够满足所有请求 n for(int i=0; i i+) CloseHandle(threadi); CloseHandle(mutex); CloseHandle(full); CloseHandle(empty); system(pause7、实验总结: 本次实验基于书上的生产者消费者问题,原理在上课的时候老师已经详细地讲解过,但是在具体编程实现的过程中也遇到了很多问题,除了书上的库函数之外还有一些函数书上并没有给出用法,比如如何创建线程等函数,通过查阅参考相关资料解决,通过编写代码也系统地理解了生产者消费者问题的操作过程,线程的创建,信号量的创建以及信号量的使用方法等情况,遇到的好多编代码上的细节问题通过反复调试解决,有较大收获。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1