- 1、本文档共19页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验二生产者与消费者讲解
操作系统原理实验;实验二 进程的互斥与同步(生产者与消费者问题);本实验要求设计在同一个进程地址空间内执行的两个线程。生产者线程生产物品,然后将物品放置在一个空缓冲区中供消费者线程消费。消费者线程从缓冲区中获得物品,然后释放缓冲区。
生产者线程生产物品时,若无空缓冲区可用,生产者线程必须等待消费者线程释放出一个空缓冲区;消费者线程消费物品时,若缓冲区为空,消费者线程将被阻塞,直到新的物品被生产出来。;本实验要求设计并实现一个进程,该进程拥有一个生产者线程和一个消费者线程,它们使用N个不同的缓冲区(N为一个确定的数值,例如N=32)。需要使用如下信号量:
l?一个互斥信号量,用以阻止生产者线程和消费者线程同时操作缓冲区列表;
l? 一个信号量,当生产者线程生产出一个物品时可以用它向消费者线程发出信号;
l? 一个信号量,消费者线程释放出一个空缓冲区时可以用它向生产者线程发出信号;;线程创建;线程创建;ExitThread
函数功能:该函数结束一个线程。
函数原型:
VOID ExitThread( DWORD dwExitCode );
参数:
dwExitCode:定义调用线程的退出代码。使用GetExitCodeThread函数来检取一个线程的退出代码。
返回值:无。 ;函数功能:该函数创建有名或无名的互斥对象。
函数原型:
HANDLE CreateMutex(
LPSECURITY_ATTRIBUTES lpMutexAttributes,
BOOL bInitialOwner,
LPCTSTR lpName );;函数功能:该函数释放指定互斥对象。
函数原型:
ReleaseMutex(HANDLE hMutex);
参数:
hMutex:互斥对象句柄。为CreateMutex或OpenMutex函数的返回值。
返回值:
如果函数调用成功,则返回值是非零值;如果函数调用失败,则返回值为0。;函数功能:测试指定对象是否有信号或超时。
函数原型:
DWORD WaitForSingleObject(
HANDLE hHandle,DWORD dwMilliseconds);
参数:
hHandle:等待对象句柄。
dwMilliseconds:指定以毫秒为单位的超时间隔。
返回值:
如果函数调用成功,返回值表明引起函数返回的事件。
如果函数调用失败,返回值是WAIT_FAILED。;函数功能:该函数是创建一个有名或者无名信号对象。
函数原型:
HANDLE CreateSemaphore(
LPSECURITY_ATTRIBUTES lpAttributes,
LONG lInitialCount,
LONG lMaximumCount,
LPCTSTR lpName);
返回值:
如果成功就传回一个handle,否则传回NULL。;函数功能:该函数将指定信号对象的计数增加一个指定的数量。
函数原型:
ReleaseSemaphore(
HANDLE hSemaphore,
LONG lReleaseCount,
LPLONG lpPreviousCount);
返回值:
如果成功,则传回TRUE。否则传回FALSE。;进程的互斥与同步。编写一段程序,模拟生产者和消费者线程,实现进程的互斥与同步。
利用VC++6.0实现上述程序设计和调试操作,对于生产者和消费者线程操作的成功与否提供一定的提示框。
通过阅读和分析实验程序,熟悉进程的互斥与同步的概念。;在开始本实验之前,请回顾教科书的相关内容
需要做以下准备:
一台运行Windows 2000 /XP 操作系统的计算机
计算机中需安装Visual C++ 6.0专业版或企业版;#define N …
//定义信号量
HANDLE m_S_Empty;? // 生产者Semaphore
HANDLE m_S_Full; // 消费者Semaphore
HANDLE m_M_Mutex;//互斥
buf_type buffer[N]; //定义共享缓冲区
main(…)
{ …
//创建生产者和消费者线程
CreateThread(…, Producer, …);
CreateThread(…, Consumer, …);
m_S_Empty = CreateSemaphore(NULL, N, N, NULL);?
//初始计数为N
????m_S_Full = CreateSemaphore(NULL, 0, N, NULL);?
//初始计数为0
??? m_M_Mutex = CreateMutex(NULL, FALSE, NULL);
…};Produ
您可能关注的文档
- PPT制作相关元素.ppt
- PPT南京国民政府.pptx
- 实际问题与一元二次方程(所有分类)讲解.ppt
- PPT图文排版心得(一).doc
- PMP串讲讲义.ppt
- PPT培训教程之四.pptx
- 实际问题与一元一次方程讲解.ppt
- 实训指导2.2利用数字证书保护通信讲解.ppt
- 实际问题与方程例4讲解.ppt
- 实际问题与方程 例2讲解.ppt
- 高中数学 1-3-1-1 函数的单调性能力强化提升 新人教A版必修1.doc
- -高中语文 第6课辛弃疾词两首同步检测 新人教版必修4 .doc
- 高中物理 1.5 电势差练习 新人教版选修3-1.doc
- 高中英语 Unit4 Making the+news综合测试题 新人教版必修5.doc
- 高中数学 4-2-3 直线与圆的方程的应用能力强化提升 新人教A版必修2.doc
- 高中数学 第一次月综合素能检测 新人教A版必修1.doc
- 高中数学 3.4 简单线性规划(第1课时)练习 北师大版必修5.doc
- 高中数学 2-2-2 平面与平面平行的判定能力强化提升 新人教A版必修2.doc
- 高中数学 1-3-2 球的体积和表面积能力强化提升 新人教A版必修2.doc
- 高中数学 3.3 二元一次不等式组与简单的线性规划问题第3课时练习 .doc
文档评论(0)