欢迎来到天天文库
浏览记录
ID:58604243
大小:189.54 KB
页数:42页
时间:2020-10-18
《缓冲池模拟与实现.pdf》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、长春理工大学大学学生实验报告书学生用表实验名称缓冲池的模拟实现课程名称操作系统课程号学院(系)软件学院专业软件工程班级学生姓名学号实验地点实验日期一、实验目的1掌握缓冲池的结构2掌握缓冲池的使用方法二、实验内容1、实现输入、计算、输出进程并发执行2、实现getBuf和putBuf函数。三、实验步骤1、整体设计包括三个线程的模拟设计三个队列的链表设计还有三个队列的同步与互斥的设计等2、由于本次实验没有需要太多的数据结构因此数据结构的设计就只有三个缓冲队列的设计先构造一个空的缓冲队列该队列是一个实体即是一个确定的有结点的链表它是模拟缓冲池的载体输入与输出
2、队列在构造时只有它的头尾指针而没有它的实体这是因为它可以从空缓冲区里获得例如当计算线程要数据计算时便可从空队列里获取一个缓冲区作为输入缓冲使用再把它挂载到输入队列的队尾中去算法流程图实验内容如下//缓冲队列类型的定义#defineEMQ0//空缓冲队列#defineINQ1//输入缓冲队列#defineOUTQ2//输出缓冲队列constintbufferpoolsize=50;////缓冲池大小,默认设置为50个//结束运行标志shortintm_end;GDOU-B-11-112//缓冲结构体的定义typedefstructBuffer{intB
3、ufNo;//缓冲区号intbuf;//缓冲内容Buffer*next;//缓冲指向下一个指针}buffer;//线程函数声明DWORDWINAPIInputThreadFunc(LPVOIDlpPara);//输入线程函数DWORDWINAPIOutputThreadFunc(LPVOIDlpPara);//输出线程函数DWORDWINAPICalThreadFunc(LPVOIDlpPara);//计算线程函数//加入与摘取队列函数声明voidputBuf(inttype,buffer*buf);//挂载到队列尾buffer*getBuf(int
4、type);//从队列头中摘取一个缓冲区//构造缓冲池函数的声明voidConstructBuffer();//线程的句柄HANDLEhInputT;//输入线程HANDLEhOutputT;//输出线程HANDLEhCalculateT;//计算线程//线程的IDDWORDInputTid;//输入线程DWORDOutputTid;//输出线程DWORDCalculateTid;//计算线程//三个互斥量信号句柄HANDLEhmutexEMQ;//空队列的互斥信号量HANDLEhmutexOUTQ;//装满输出队列的互斥信号量HANDLEhmute
5、xINQ;//装满输入队列的互斥信号量//三个同步信号量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、<7、eateSemaphore(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=Create8、Thread(NULL,0,OutputThreadFunc,NULL,0,&OutputTid);//Sl
6、<7、eateSemaphore(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=Create8、Thread(NULL,0,OutputThreadFunc,NULL,0,&OutputTid);//Sl
7、eateSemaphore(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=Create
8、Thread(NULL,0,OutputThreadFunc,NULL,0,&OutputTid);//Sl
此文档下载收益归作者所有