操作系统实验报告实验二_第1页
操作系统实验报告实验二_第2页
操作系统实验报告实验二_第3页
操作系统实验报告实验二_第4页
操作系统实验报告实验二_第5页
已阅读5页,还剩3页未读 继续免费阅读

付费下载

下载本文档

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

文档简介

进程死锁模拟实验实验题目进程死锁模拟实验实验目的1)进一步理解线程的概念2)进一步熟悉进程,线程同步的概念3)深刻理解死锁的概念4)深刻理解操作系统对多线程跳读的管理5)深刻理解临界区和互斥的概念实验内容本次试验模拟的两个线程完成销售车票的过程。一方面,利用关键代码(临界区)实现线程同步;另一方面,模拟实现线程死锁。通过本次的实验,进一步理解VC下关键代码段(即临界区)和相关API函数(在参考代码中的黑体字)。分析线程同步的参考代码,分析运行结果,理解线程同步的概念。设计思路和算法启动售票系统启动售票系统启动售票线程1启动售票系统2启动售票线程1启动售票系统2Tickets>0?tickets>0?Tickets>0?tickets>0?NNYYNNYYNN能进入临界区A?NN能进入临界区A?Y能否进入临界区A? Y能否进入临界区A?Y进入临界区A进入临界区AY进入临界区A进入临界区ANNtickets>0?tickets>0?NNtickets>0?tickets>0?YYYY售出一张票,tickets减1售出一张票,tickets减1售出一张票,tickets减1售出一张票,tickets减1离开临界区A离开临界区A离开临界区A离开临界区A线程2终止线程1终止线程2终止线程1终止主要数据结构及其说明1.CloseHandle()函数Closehandle函数的一般形式如下;BOOLClosehandle(HANDLEhObject);函数功能:关闭一个内核对象。其中包括文件、文件映射、进程、线程、安全和同步对象等。在CreateThread成功之后会返回一个hThreadle的handle,且内核的计数加1,CloseHandle之后,引用计数减1,当变为0,系统删除内核对象。参数说明: hObject代表一个已打开对象handle。返回值: TRUE 执行成功 FAlSE执行失败若在线程执行完之后,没有调用CloseHandle,在进程执行期间,将会造成内核对象的泄露,相当于句柄泄露,但不同于内核泄漏,这势必会对系统的效率带来一定程度上的负面影响。但当进程结束退出后,系统会自动清理这些资源。2.Sleep()函数Sleep()函数的一般的形式如下;Sleep(unisgnedlong);Sleep()函数是C++中头文件<windows.h>下的函数,其作用是延时,即程序暂停若干时间。时间就是它的参数,单位是毫秒。 其中,Sleep()里面的单位是以毫秒为单位的,如果想让函数滞留1秒的话,应该是Sleep(1000)。测试数据及其测试结果分析7.实验体会通过这次实验使我体会到仅靠学习理论知识是远远不够的,要与实际动手操作相结合才能更好的理解和分析问题。8.源程序文件#include<windows.h>#include<iostream.h>DWORDWINAPIFun1Proc(LPVOIDlpParameter);DWORDWINAPIFun2Proc(LPVOIDlpParameter);inttickets=100;CRITICAL_SECTIONg_csA;voidmain(){ HANDLEhThread1; HANDLEhThread2; hThread1=CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);//创建进程 hThread2=CreateThread(NULL,0,Fun2Proc,NULL,0,NULL); CloseHandle(hThread1); CloseHandle(hThread2); InitializeCriticalSection(&g_csA);//创建临界区对象 Sleep(4000); DeleteCriticalSection(&g_csA);//程序退出前释放临界区对象资源}DWORDWINAPIFun1Proc(LPVOIDlpParameter)//THREADDATA{ while(TRUE) { EnterCriticalSection(&g_csA);//判断能否进入临界区 Sleep(1); if(tickets>0) { Sleep(1); cout<<"thread1sellticket:"<<tickets--<<endl; LeaveCriticalSection(&g_csA);//释放临界区对象所有权 } else { LeaveCriticalSection(&g_csA); break; } } return0;}DWORDWINAPIFun2Proc(LPVOIDlpParameter)//threaddata{ while(TRUE) { EnterCriticalSection(&g_csA); Sleep(1); if(tickets>0) { Sleep(1); cout<<"thread2sellticket:"

温馨提示

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

评论

0/150

提交评论