缓冲池模拟与实现_第1页
缓冲池模拟与实现_第2页
缓冲池模拟与实现_第3页
缓冲池模拟与实现_第4页
缓冲池模拟与实现_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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

2、出队列在构造时只有它的头尾指针而没有它的实体这是因为它可以从空缓冲区里获得例如当计算线程要数据计算时便可从空队列里获取一个缓冲区作为输入缓冲使用再把它挂载到输入队列的队尾中去 算法流程图 实验内容如下 /缓冲队列类型的定义 #define EMQ 0 /空缓冲队列 #define INQ 1 /输入缓冲队列 #define OUTQ 2 /输出缓冲队列 const int bufferpoolsize = 50; /缓冲池大小,默认设置为50个 /结束运行标志 short int m_end ; GDOU-B-11-112 /缓冲结构体的定义 typedef struct Buffer int

3、 BufNo; /缓冲区号 int buf; /缓冲内容 Buffer *next; /缓冲指向下一个指针 buffer; /线程函数声明 DWORD WINAPI InputThreadFunc(LPVOID lpPara); /输入线程函数 DWORD WINAPI OutputThreadFunc(LPVOID lpPara); /输出线程函数 DWORD WINAPI CalThreadFunc(LPVOID lpPara); /计算线程函数 /加入与摘取队列函数声明 void putBuf(int type , buffer *buf); /挂载到队列尾 buffer* getBuf

4、(int type); /从队列头中摘取一个缓冲区 /构造缓冲池函数的声明 void ConstructBuffer(); /线程的句柄 HANDLE hInputT; /输入线程 HANDLE hOutputT; /输出线程 HANDLE hCalculateT; /计算线程 /线程的ID DWORD InputTid; /输入线程 DWORD OutputTid; /输出线程 DWORD CalculateTid; /计算线程 /三个互斥量信号句柄 HANDLE hmutexEMQ; /空队列的互斥信号量 HANDLE hmutexOUTQ; /装满输出队列的互斥信号量 HANDLE hm

5、utexINQ; /装满输入队列的互斥信号量 /三个同步信号量 HANDLE hsemINQ; HANDLE hsemOUTQ; HANDLE hsemEMQ; #include "windows.h" #include "iostream" #include "stdlib.h" #include "time.h" #include "Main1.h" using namespace std; /三个缓冲队列头与尾指针 buffer *hemq , *hinq , *houtq; /队头指针

6、buffer *lemq , *linq , *loutq; /队尾指针 /主函数 int main() cout<<show1<<endl<<show2<<endl<<show3<<endl<<endl; m_end = 1 ; /运行结束标志 ConstructBuffer(); /构造缓冲池 /创建互斥对象 hmutexEMQ = CreateMutex(NULL,FALSE,NULL); hmutexOUTQ = CreateMutex(NULL,FALSE,NULL); hmutexINQ = Cre

7、ateMutex(NULL,FALSE,NULL); /创建信号量对象 hsemINQ = CreateSemaphore(NULL,0,bufferpoolsize,NULL); hsemOUTQ = CreateSemaphore(NULL,0,bufferpoolsize,NULL); hsemEMQ = CreateSemaphore(NULL,bufferpoolsize,bufferpoolsize,NULL); /创建线程 hInputT = CreateThread(NULL,0,InputThreadFunc,NULL,0,&InputTid); Sleep(10);

8、 hCalculateT = CreateThread(NULL,0,CalThreadFunc,NULL,0,&CalculateTid); Sleep(10); hOutputT = CreateThread(NULL,0,OutputThreadFunc,NULL,0,&OutputTid); /Sleep(10000); /system("pause"); if(getchar() /按回车后终止程序运行 m_end = 0 ; cout<<"程序已经终止!"<<endl; /等待三个线程的结束返回 Wai

9、tForSingleObject(hInputT,INFINITE); WaitForSingleObject(hCalculateT,INFINITE); WaitForSingleObject(hOutputT,INFINITE); /释放线程的资源 CloseHandle(hInputT); CloseHandle(hCalculateT); CloseHandle(hOutputT); return 0; /输入线程函数的实现 DWORD WINAPI InputThreadFunc(LPVOID lpPara) /输入线程函数 int nRandom; buffer* getbuf;

10、 srand(time(0); /保证每次运行时产生的随机数独立 while(m_end) Sleep(100); nRandom = rand()%100 + 1 ; /产生1到100的随机数 /同步与互斥的控制 WaitForSingleObject(hsemEMQ,INFINITE); WaitForSingleObject(hmutexEMQ,INFINITE); getbuf = getBuf(EMQ); /访问空队列 getbuf->buf = nRandom ; cout<<"输入线程从 "<<"缓冲单元 "&

11、lt;<getbuf->BufNo<<"-收容输入->"<<"data= "<<getbuf->buf<<endl; ReleaseMutex(hmutexEMQ); /释放互斥对象信号 /控制访问输入队列的互斥量 WaitForSingleObject(hmutexINQ,INFINITE); putBuf(INQ,getbuf) ; /将输入的缓冲区挂载到输入队列的队尾 ReleaseMutex(hmutexINQ); ReleaseSemaphore(hsemINQ,1,NUL

12、L); return 0; /输出线程函数的实现 DWORD WINAPI OutputThreadFunc(LPVOID lpPara) /输出线程函数 buffer* Outputbuf ; /一个临时交换区 while(m_end) Sleep(100); /同步与互斥的控制 WaitForSingleObject(hsemOUTQ,INFINITE); WaitForSingleObject(hmutexOUTQ,INFINITE); Outputbuf = getBuf(OUTQ) ; /从输出队列中提取一个提取输出缓冲区 cout<<"输出线程从 "

13、<<"缓冲单元 "<<Outputbuf->BufNo<<"-提取输出->"<<"data= "<<Outputbuf->buf<<endl; /Outputbuf->buf = -1 ; /提取完成后将该缓冲区回收 ReleaseMutex(hmutexOUTQ); WaitForSingleObject(hmutexEMQ,INFINITE); putBuf(EMQ,Outputbuf) ; /回收的把它挂载到空队列的队尾 Releas

14、eMutex(hmutexEMQ); ReleaseSemaphore(hsemEMQ,1,NULL); return 0; /计算线程函数的实现 DWORD WINAPI CalThreadFunc(LPVOID lpPara) /计算线程函数 buffer* Calbuf1 = NULL; buffer* Calbuf2 =NULL; int nCal; while(m_end) Sleep(10); /因为计算线程的速度远远快于输入与输出线程所以它的休眠时间应很小 /同步与互斥的控制 WaitForSingleObject(hsemINQ,INFINITE); WaitForSingle

15、Object(hmutexINQ,INFINITE); Calbuf1 = getBuf(INQ); /从输入队列中提取一个收容输入缓冲区 nCal = Calbuf1->buf; /提取数据 cout<<"计算线程从 "<<"缓冲单元 "<<Calbuf1->BufNo<<"-提取输入->"<<"data= "<<Calbuf1->buf<<endl; /Calbuf->buf = -1 ; /系统将

16、收回此缓冲区表示该缓冲区已空 ReleaseMutex(hmutexINQ); WaitForSingleObject(hmutexEMQ,INFINITE); putBuf(EMQ,Calbuf1); ReleaseMutex(hmutexEMQ); ReleaseSemaphore(hsemEMQ,1,NULL); nCal = nCal + 10000 ; /模拟输入数据的处理 WaitForSingleObject(hsemEMQ,INFINITE); WaitForSingleObject(hmutexEMQ,INFINITE); Calbuf2 = getBuf(EMQ); /得到

17、一个空的缓冲区作为收容输出 Calbuf2->buf = nCal ; /存入运算结果 cout<<"计算线程从 "<<"缓冲单元 "<<Calbuf2->BufNo<<"-收容输出->"<<"data= "<<Calbuf2->buf<<endl; ReleaseMutex(hmutexEMQ); WaitForSingleObject(hmutexOUTQ,INFINITE); /把收容输出缓冲区挂载到输

18、出队列的队尾 putBuf(OUTQ,Calbuf2); ReleaseMutex(hmutexOUTQ); ReleaseSemaphore(hsemOUTQ,1,NULL); return 0 ; /从队列中得到队头结点函数(实际相当于删除一个结点操作) buffer* getBuf(int type) buffer* Returnbuf = NULL; switch(type) case 0 : /判断该队列的缓冲个数是否还只有一个 if(hemq != lemq && hemq->next->next != NULL) Returnbuf = hemq-&g

19、t;next ; /取得队列头 hemq->next = Returnbuf->next; /修正队列链表头指针的指向 Returnbuf->next = NULL; return Returnbuf; else /假如该缓冲队列的个数只有一个的话则使得队头指针与队尾指针相等级 /这样的话就可以防止队尾指针的丢失 Returnbuf = hemq->next ; hemq->next = Returnbuf->next; Returnbuf->next = NULL; lemq = hemq ; return Returnbuf; break; cas

20、e 1: if(hinq != linq && hinq->next->next != NULL) Returnbuf = hinq->next; hinq->next = Returnbuf->next; Returnbuf->next =NULL; return Returnbuf; else Returnbuf = hinq->next ; hinq->next = Returnbuf->next; Returnbuf->next = NULL; linq = hinq; return Returnbuf; br

21、eak; case 2: if(houtq != loutq && houtq->next->next !=NULL ) Returnbuf = houtq->next ; houtq->next = Returnbuf->next; Returnbuf->next = NULL; return Returnbuf; else Returnbuf = houtq->next; houtq->next = Returnbuf->next ; Returnbuf->next = NULL; loutq = houtq; return Returnbuf; break; /把某一类型的缓冲区挂载到队尾函数 /(实际相当于插入一个结点操作) void putBuf(int type , buffer* buf) switch(type) case 0: if(buf != NULL) /该参数(buf)不为空的时候才执行因为插入一个空的缓冲区是没有意义的 lemq->next = buf; /修正队列尾指针 lemq = buf ; /队尾指针的跟踪 lemq-

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论