操作系统原理实验五

上传人:wt****50 文档编号:33662957 上传时间:2018-02-16 格式:DOC 页数:5 大小:57KB
返回 下载 相关 举报
操作系统原理实验五_第1页
第1页 / 共5页
操作系统原理实验五_第2页
第2页 / 共5页
操作系统原理实验五_第3页
第3页 / 共5页
操作系统原理实验五_第4页
第4页 / 共5页
操作系统原理实验五_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《操作系统原理实验五》由会员分享,可在线阅读,更多相关《操作系统原理实验五(5页珍藏版)》请在金锄头文库上搜索。

1、实验五 线程的同步1、 实验目的(1) 进一步掌握 Windows 系统环境下线程的创建与撤销。(2) 熟悉 Windows 系统提供的线程同步 API。(3) 使用 Windows 系统提供的线程同步 API 解决实际问题。2、 实验准备知识:相关 API 函数介绍 等待对象等待对象(wait functions)函数包括等待一个对象(WaitForSingleObject() )和等待多个对象(WaitForMultipleObject() )两个 API 函数。1) 等待一个对象WaitForSingleObject()用于等待一个对象。它等待的对象可以为以下对象之一。Change on

2、tification:变化通知。Console input: 控制台输入。Event:事件。Job:作业。Mutex:互斥信号量。Process:进程。Semaphore:计数信号量。Thread:线程。Waitable timer:定时器。原型:DWORD WaitForSingleObject(HANDLE hHandle, / 对象句柄DWORD dwMilliseconds / 等待时间) ;参数说明:(1) hHandle:等待对象的对象句柄。该对象句柄必须为 SYNCHRONIZE 访问。(2) dwMilliseconds:等待时间,单位为 ms。若该值为 0,函数在测试对象的状

3、态后立即返回,若为 INFINITE,函数一直等待下去,直到接收到一个信号将其唤醒,如表 2-1 所示。返回值:如果成功返回,其返回值说明是何种事件导致函数返回。表 2-1 函数描述访问 描述WAIT ABANDONED 等待的对象是一个互斥(Mutex)对象,该互斥对象没有被拥有它的线程释放,它被设置为不能被唤醒WAIT OBJECT 0 指定对象被唤醒WAIT TIMEOUT 超时用法举例:Static HANDLE hHandlel = NULL;DWORD dRes;dRes = WaitForSingleObject(hHandlel,10); /等待对象的句柄为 hHandlel,

4、等待时间为10ms2) 等待对个对象WaitForMultiple()bject()在指定时间内等待多个对象,它等待的对象与WaitForSingleObject()相同。原型:DWORD WaitForMultipleObjects(DWORD nCount, /句柄数组中的句柄数CONST HANDLE * lpHandles, /指向对象句柄数组的指针BOOL fWaitAll, /等待类型DWORD dwMilliseconds /等待时间) ;参数说明:(1) nCount:由指针 * lpHandles 指定的句柄数组中的句柄数,最大数是MAXIMUM WAIT OBJECTS。(

5、2) * lpHandles:指向对象句柄数组的指针。(3) fWaitAll:等待类型。若为 TRUE,当由 lpHandles 数组指定的所有对象被唤醒时函数返回;若为 FALSE,当由 lpHandles 数组指定的某一个对象被唤醒时函数返回,且由返回值说明是由于哪个对象引起的函数返回。(4) dwMilliseconds:等待时间,单位为 ms。若该值为 0,函数测试对象的状态后立即返回;若为 INFINITE,函数一直等待下去,直到接收到一个信号将其唤醒。返回值:、如果成功返回,其返回值说明是何种事件导致函数返回。各参数的描述如表 2-2 所示。表 2-2 各参数描述访问 描述WAI

6、T OBJECT 0 to(WAIT OBJECT 0nCount-1) 若 bWaitAll 为 TRUE,返回值说明所有被等待的对象均被唤醒;若 bWaitAll 为 FALSE,返回值减去 WAIT OBJECT 0 说明 lpHandles 数组下标指定的对象满足等待条件。如果调用时多个对象同时被唤醒,则取多个对象中最小的那个数组下标WAIT ABANDONED 0 to(WAIT ABANDONED 0nCount-1)若 bWaitAll 为 TRUE,返回值说明所有被等待的对象均被唤醒,并且至少有一个对象是没有约束的互斥对象;若 bWaitAll 为 FALSE,返回值减去 WA

7、IT ABANDONED 0 说明 lpHandles 数组下标指定的没有约束的互斥对象满足等待条件WAIT TIMEOUT 超时且参数 bWaitAll 指定的条件不能满足 信号量对象(Semaphore)信号量对象(Semaphore)包括创建信号量(CreateSemaphore() ) 、打开信号量(OpenSemaphore() )及增加信号量的值(ReleaseSemaphore() )API 函数。1) 创建信号量CreateSemaphore() )用于创建一个信号量。原型:HANDLE CreateSemaphore(LPSECURITY ATTRIBUTES lpSemap

8、horeAttributes, /安全属性LONG lInitialCount, /信号量对象的初始值LONG lMaximumCount, /信号量的最大值LPCTSTR lpName /信号量名) ;参数说明:(1)lpSemaphoreAttributes:指定安全属性,为 NULL 时,信号量得到一个默认的安全描述符。(2) lInitialCount:指定信号量对象的初始值。该值必须大于等于 0,小于等于lMaximumCount。当其值大于 0 时,信号量被唤醒。当该函数释放了一个等待该信号量的线程时,lInitialCount 值减 1,当调用函数ReleaseSemaphore

9、()时,按其指定的数量加一个值。(3) lMaximumCount:指出该信号量的最大值,该值必须大于 0。(4) lpName:给出信号量的名字。返回值:信号量创建成功,将返回该信号量的句柄。如果给出的信号量名是系统已经存在的信号量,将返回这个已存在信号量的句柄。如果失败,系统返回 NULL,可以调用函数GetLastError()查询失败的原因。用法举例:Static HANDLE hHandlel= NULL; /定义一个句柄/创建一个信号量,其初始值为 0,最大值为 5,信号量的名字为“SemphoreNamel”HHandle=CreateSemaphore(NULL,0,5, “S

10、emphoreNamel”) ;2) 打开信号量OpenSemaphore()用于打开一个信号量。原型:HANDLE OpenSemaphore(DWORD dWDesiredAccess, /访问标志BOOL bInheritHandle, /继承标志LPCTSTR lpName /信号量名) ;参数说明:(1) dwDesiredAccess:指出打开后要对信号量进行何种访问,如表 2-3所示。表 2-3 访问状态访问 描述SEMAPHORE ALL ACCESS 可以进行任何对信号量的访问SEMAPHORE MODIFY STATE 可使用 ReleaseSemaphore()修改信号量

11、的值,使信号量成为可用状态SYNCHRONIZE 使用等待函数(wait functions) ,等待信号量成为可用状态(2)bInheritHandle:指出返回的信号量句柄是否可以继承。(3)lpName:给出信号量的名字。返回值:信号量打开成功,将返回该号量的句柄;如果失败,系统返回 NULL,可以调用函数 GetLastError()查询失败的原因。用法举例:static HANDLE hHandlel= NULL ;/打开一个名为“SemphoreNamel”的信号量,之后可使用ReleaseSemaphore()函数增加信号量的值 hHandlel= OpenSemaphore(S

12、EMAPHORE MODIFY STATE,NULL, “SemphoreNamel”) ;3) 增加信号量的值ReleaseSemaphore()用于增加信号量的值。原型:BOOL ReleaseSemaphore(HANDLE hSemaphore, /信号量对象句柄LONG lReleaseCount, /信号量要增加数值LPLONG lpPreviousCount /信号量要增加数值的地址) ;参数说明:(1) hSemaphore:创建或打开信号量时给出的信号量对象句柄。Windows NT 中建议要使用 SEMAPHORE MODIFY STATE 访问属性打开该信号量。(2) I

13、ReleaseCount:信号量要增加的数值。该值必须大于 0。如果增加该值后,大于信号量创建时给出的 lMaximumCount 值,则增加操作失效,函数返回 FALSE。(3) LpPreviousCounte:接收信号量值的一个 32 位的变量。若不需要接收该值,可以指定为 NULL。返回值:如果成功,将返回一个非 0 值;如果失败,系统返回 0,可以调用函数GetLastError()查询失败的原因。用法举例:static HANDLE hHandlel= NULL;BOOL rc;Rc= ReleaseSemaphore(hHandlel,l,NULL); /给信号量的值加 13、

14、实验内容完成主、子两个线程之间的同步,要求子线程先执行。在主线程中使用系统调用GreateThread()创建一个子线程。主线程创建子线程后进入阻塞状态,直到子线程运行完毕后唤醒主线程。4、 实验要求能正确使用等待对象 WaitForSingleObject()或 WaitForMultipleObject()及信号量对象 CreateSemaphore() 、OpenSemaphore() 、ReleaseSemaphore()等系统调用,进一步理解线程的同步。5、 实验指导具体操作过程:在 MicrosoftVisual C+ 6.0 环境下建立一个 MFC 支持的控制台工程文件,编写 C

15、 程序,在程序中使用CreateSemaphore(NULL,0,1, “SemaphoreNamel”)创建一个名为“SemaphoreNamel”的信号量,信号量的初始值为 0,之后使用 0penSemaphore(SYNCHRONIZE|SEMAPHOSE MODIFY STATE,NULL, “SemaphoreNamel”)打开该信号量,这里访问标志用“SYNCHRONIZE|SEMAPHORE MODIFY STATE”,以便之后可以使用 WaitForSingleObject()等待该信号量及使用 ReleaseSemaphore()释放该信号量,然后创建一个子线程,主线程创建子线程后调用 WaitForSingleObject(hHandlel,INFINITE) ,这里等待时间设置为INFINITE 表示要一直等待下去,直到该信号量被唤醒为止。子线程结束,调用ReleaseSemaphore(hHandlel,1,NULL)释放信号量,使信号量的值加 1。6、 实验总结该实验完成了主、子线程

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号