缓冲池地模拟使用

缓冲池地模拟使用

ID:30216554

大小:51.00 KB

页数:9页

时间:2018-12-27

缓冲池地模拟使用_第1页
缓冲池地模拟使用_第2页
缓冲池地模拟使用_第3页
缓冲池地模拟使用_第4页
缓冲池地模拟使用_第5页
资源描述:

《缓冲池地模拟使用》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、实用标准文案GDOU-B-11-112广东海洋大学学生实验报告书(学生用表)实验名称缓冲池的模拟使用课程名称操作系统课程号学院(系)软件学院专业软件工程班级学生姓名学号实验地点实验日期一、实验目的(1)掌握缓冲池的结构(2)掌握缓冲池的使用方法二、实验内容1、实现输入、计算、输出进程并发执行;2、实现getBuf和putBuf函数。三、实验步骤1、整体设计,包括三个线程的模拟设计,三个队列的链表设计,还有三个队列的同步与互斥的设计等;2、由于本次实验没有需要太多的数据结构,因此,数据结构的设计就只有三个缓冲队列的设计:先构造一个空的缓冲队列,该队列是一个实体,即是一

2、个确定的有结点的链表,它是模拟缓冲池的载体,输入与输出队列在构造时只有它的头尾指针,而没有它的实体,这是因为它可以从空缓冲区里获得,例如,当计算线程要数据计算时,便可从空队列里获取一个缓冲区,作为输入缓冲使用再把它挂载到输入队列的队尾中去实验内容如下://缓冲队列类型的定义#defineEMQ0//空缓冲队列#defineINQ1//输入缓冲队列#defineOUTQ2//输出缓冲队列constintbufferpoolsize=50;////缓冲池大小,默认设置为50个//结束运行标志shortintm_end;精彩文档实用标准文案//缓冲结构体的定义typede

3、fstructBuffer{intBufNo;//缓冲区号intbuf;//缓冲内容Buffer*next;//缓冲指向下一个指针}buffer;//线程函数声明DWORDWINAPIInputThreadFunc(LPVOIDlpPara);//输入线程函数DWORDWINAPIOutputThreadFunc(LPVOIDlpPara);//输出线程函数DWORDWINAPICalThreadFunc(LPVOIDlpPara);//计算线程函数//加入与摘取队列函数声明voidputBuf(inttype,buffer*buf);//挂载到队列尾buffer*

4、getBuf(inttype);//从队列头中摘取一个缓冲区//构造缓冲池函数的声明voidConstructBuffer();//线程的句柄HANDLEhInputT;//输入线程HANDLEhOutputT;//输出线程HANDLEhCalculateT;//计算线程//线程的IDDWORDInputTid;//输入线程DWORDOutputTid;//输出线程DWORDCalculateTid;//计算线程//三个互斥量信号句柄HANDLEhmutexEMQ;//空队列的互斥信号量HANDLEhmutexOUTQ;//装满输出队列的互斥信号量HANDLEhmu

5、texINQ;//装满输入队列的互斥信号量//三个同步信号量HANDLEhsemINQ;HANDLEhsemOUTQ;HANDLEhsemEMQ;#include"windows.h"精彩文档实用标准文案#include"iostream"#include"stdlib.h"#include"time.h"#include"Main1.h"usingnamespacestd;//三个缓冲队列头与尾指针buffer*hemq,*hinq,*houtq;//队头指针buffer*lemq,*linq,*loutq;//队尾指针//主函数intmain(){cout<

6、how1<

7、Semaphore(NULL,0,bufferpoolsize,NULL);hsemEMQ=CreateSemaphore(NULL,bufferpoolsize,bufferpoolsize,NULL);//创建线程hInputT=CreateThread(NULL,0,InputThreadFunc,NULL,0,&InputTid);Sleep(10);hCalculateT=CreateThread(NULL,0,CalThreadFunc,NULL,0,&CalculateTid);Sleep(10);hOutputT=CreateThread(NUL

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。