附件(四)深 圳 大 学 实 验 报 告 课程名称: 操作系统 实验项目名称: 进程(线程)同步及死锁 学院: 计算机与软件学院 专业: 计算机科学与技术 指导老师: 报告人: 学号: 班级: 实验时间: 2 01 5 / 1 0 / 23 实验报告提交时间: 20 1 5/ 1 1 /1 3 教务处制一、实验目得与要求:实验目得:在多进程(线程)运行环境中,进程(线程)之间并发执行,假如对进程(线程)访问临界资源(如公共变量)得操作不加限制,就会产生“与时间有关"得错误。为防止这类错误,必须用同步机构控制进程(线程)对临界资源(公共变量)得访问。在一个进程(线程)需要两个或两个以上得临界资源时,假如申请与推动顺序不当,会造成死锁,即多个进程(线程)因竞争临界资源而造成得一种僵局,若无力作用,这些进程(线程)都将永远不会再向前执行。本实验利用 W i ndo w系统提供得同步机制,来协调线程(Thre ad)间得并发执行,并比较各种预防死锁得措施,以加深对同步机制与死锁得理解,并学会在并发程序中引用同步机构,并预防死锁得编程方法。实验要求:熟悉 Wi n dows 操作系统及V C 程序设计方法。二、方法、步骤: 设计解决哲学家就餐问题得并发线程。假定有 6 个哲学家,围着圆桌交替地进行思考与进餐;每次进餐时,必须同时拿到左右两边得两只筷子才能进餐;进餐后,再放下筷子思考。这就是一个典型得同时需要两个资源得例子,假如申请资源顺序不当,可能会引起死锁.本实验设计 6 个哲学家共享一个相同得线程P h i l o s o pher,既完成线程同步,又预防死锁发生。实验中采纳了3种预防死锁得方法(摒弃‘环路等待’条件,摒弃‘请求与保持'条件,摒弃‘不剥夺’条件),要预防死锁,只采纳其中得任何一种方法即可。三.实验过程及内容:(其中:提供有简短说明得程序代码。要求:程序运行正确、符合设计要求。)1、创建工程,注意勾选 Wi n 3 2 Ap p licati o n,点击确定2、勾选第三个选项3、创建菜单,有Ea t、A b ou t、Exit4、在进程(线程)同步及死锁、cpp 中编写代码,此时代码有“摒弃‘环路等待’条件”、“摒弃‘请求与保持’条件”、“摒弃‘不剥夺’条件”三种代码,当检测其中一个时须将其余两个加以注释,一一检测其对死锁得影响.运行结果:运行前:运行后:5、在运行时可知,在分别“摒弃‘环路等待’条件”与“摒弃‘不剥夺’条件”得代码时不会出现死锁,而使...