资源预览内容
第1页 / 共26页
第2页 / 共26页
第3页 / 共26页
第4页 / 共26页
第5页 / 共26页
第6页 / 共26页
第7页 / 共26页
第8页 / 共26页
第9页 / 共26页
第10页 / 共26页
亲,该文档总共26页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-date操作系统原理实验-线程的互斥3上海电力学院上海电力学院 计算机操作系统原理实验报告 题目: 线程的同步 院系: 计算机科学与技术学院 专业年级: 信息安全2010级 学生姓名: 李鑫 学号: 20103277 同组姓名: 无 2012年 11 月13 日上海电力学院实验报告课程名称 计算机操作系统原理 实验项目 线程的同步 姓名 李鑫 学号 20103277 班级 2010251班 专业 信息安全 同组人姓名 无 指导教师姓名 徐曼 实验日期 2012/11/13 实验目的和要求:1、进一步掌握Windows系统环境下线程创建与撤销。2、熟悉Windows系统提供的线程互斥API。3、使用Windows系统提供的线程互斥API解决实际问题。实验原理与内容完成两个子线程之间的互斥。在主线程中使用系统调用CreateThread()创建两个子线程,并使两个子线程互斥地使用全局变量count。实验平台与要求 能正确使用临界区对象,包括初始化临界区InitializeCriticalSection()、进入临界区EnterCriticalSection()、退出临界区LeaveCriticalSection()及删除临界区DeleteCriticalSection(),进一步理解线程的互斥。操作系统:Windows 2000或Windows XP实验平台:Visual Studio C+ 6.0实验步骤与记录1、 启动安装好的Visual C+ 6.0。2、 选择File-New,新建Win32 Console Application控制台程序。3、 由于CreateThread()等函数是Microsoft Windows操作系统的系统调用,因此选择An application that supports MFC,之后单击Finish按钮。4、 打开编辑环境后,编辑程序,并且编译、链接并运行该程序。5、6、实验分析与结论本实验完成了两个子线程的互斥。在主程序中首先使用InitializeCriticalSection()初始化临界区,然后建立了两个子线程,在两个子线程中使用全局变量count的前后分别使用了EnterCriticalSection()进入临界区及使用LeaveCriticalSection()退出临界区,两个线程互斥的执行完成后,主线程使用DeleteCriticalSection()删除临界区并撤销线程。主要源代码:static int count=5;static HANDLE h1;static HANDLE h2;LPCRITICAL_SECTION hCriticalSection;CRITICAL_SECTION Critical;void func1();void func2();DWORD dwThreadID1,dwThreadID2;hCriticalSection=&Critical;InitializeCriticalSection(hCriticalSection);h1=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)func1,NULL,0,&dwThreadID1);if (h1=NULL)printf(Thread1 create Fail!n);elseprintf(Thread1 create Success!n);h2=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)func2,NULL,0,&dwThreadID2);if (h2=NULL)printf(Thread2 create Fail!n);elseprintf(Thread2 create Success!n);Sleep(1000);CloseHandle(h1);CloseHandle(h2);DeleteCriticalSection(hCriticalSection);ExitThread(0);void func1()int r1;EnterCriticalSection(hCriticalSection);r1=count;_sleep(500);r1=r1+1;count=r1;printf(count in func1=%dn,count);LeaveCriticalSection(hCriticalSection);void func2()int r2;EnterCriticalSection(hCriticalSection);r2=count;_sleep(500);r2=r2+1;count=r2;printf(count in func2=%dn,count);LeaveCriticalSection(hCriticalSection);实验展望(工程已经放入电子版中)使用Mutex来完成,并且使得count=33时退出,源代码:static int count=5;static HANDLE h1;static HANDLE h2;HANDLE hMutex;void func1();void func2();int _tmain(int argc, TCHAR* argv, TCHAR* envp)int nRetCode = 0;DWORD dwThreadID1,dwThreadID2;hMutex=CreateMutex(NULL,FALSE,MutexName1);/lable:h1=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)func1,NULL,0,&dwThreadID1);if (h1=NULL)printf(Thread1 create Fail!n);elseprintf(Thread1 create Success!n);h2=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)func2,NULL,0,&dwThreadID2);if (h2=NULL)printf(Thread2 create Fail!n);elseprintf(Thread2 create Success!n);Sleep(1000);/goto lable;CloseHandle(h1);CloseHandle(h2);ReleaseMutex(hMutex);ExitThread(0);return nRetCode;void func1()int r1;HANDLE hOpenMutex;while(count33)WaitForSingleObject(hMutex,INFINITE);hOpenMutex=OpenMutex(SYNCHRONIZE,NULL,MutexName1);r1=count;_sleep(500);r1=r1+1;count=r1;printf(count in func1=%dn,count);ReleaseMutex(hOpenMutex);void func2()int r2;HANDLE hOpenMutex;while(count33)WaitForSingleObject(hMutex,INFINITE);hOpenMutex=OpenMutex(SYNCHRONIZE,NULL,MutexName1);r2=count;_sleep(500);r2=r2+1;count=r2;printf(count in func2=%dn,count);ReleaseMutex(hOpenMutex); 注:实验报告内容原则上包括:实验目的与要求、实验原理与内容、实验步骤与记录、实验分析与结论等。-
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号