操作系统实验指导书014版.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统实验指导书014版,操作系统实验指导书,信号与系统实验指导书,监控系统操作指导书,作业指导书系统,系统集成作业指导书,系统运维作业指导书,系统安装作业指导书,防排烟系统作业指导书,系统运行管理指导书

本课实验从下列中自选四个完成 实验一 Linux操作系统的使用(2学时) 1、实验目的: 了解Linux的桌面环境及常用命令、学会在Linux环境下进行C语言程序编程与调试。 2、实验任务: 熟悉Linux常用命令及操作。 熟悉Vi编辑器的使用。 体会Linux下C语言编程调试方式。 3、实验要求: 记录各命令的运行结果写入实验报告中。设计思路和采取的方案) 2、实验任务: 编程实现生产者-消费者问题的模拟。 建议用C或C++语言编写源代码。 3、实验要求: 生产者消费者对缓冲区进行互斥操作。缓冲区大小为10,缓冲区满则不允许生产者生产数据,缓冲区空则不允许消费者消费数据。生产者消费者各循环操作10次。设计思路和采取的方案整个程序以伪代码形式给出,给的是框架模拟效果利用P,V操作使得在同一时刻,生产者和消费者只能有一个对存储区操作(即临界区)。如果两者同时对存储区操作,即同时取和生产的话,必定会有一个等待,当另一个完成操作后自己才会被唤醒。 生产者在存储区满时不能再生产,进入等待,消费者同理完成同步互斥效果 /*以下为代码部分*/ //定义全局变量 int empty n;//该信号量表示 int full 0;// 该信号量表示 //P操作 void P int mutex *mutex--; if *mutex 0 //当前进程挂起的程序实现 //V操作 void V int mutex *mutex++; if *mutex 0 //唤醒等待中的进程程序实现 //生产者程序 void producer P empty ;//若此时存储区空,则可以生产,否则程序挂起等待 //生产一个产品操作 显示目前产品的个数; V full ;//通知消费者进程,可以取产品 //消费者程序 void consumer P full ;//若此时存储区不空,则可以取产品,否则消费者程序挂起等待 //取走一个产品操作 V empty ;//通知生产者进程可以生产 //主函数 void main //分别调用生产者,消费者程序,顺序不限,因为已经完成信号量的同步,若发生同步问题就会等待 producer ; consumer ; consumer ; producer ; ……………… 死锁的检测和解除(2学时) 1、实验目的: 掌握死锁的概念,深入理解死锁的避免算法。 2、实验任务: 编程实现银行家算法 编程实现安全性算法 3、实验要求: 能够根据给定的资源分配情况,及某进程提出的资源请求,通过算法得出是否能进行分配。如能分配,需得出相应的安全序列。 4、设计思路和采取的方案 ① 根据银行家算法进行计算。在计算过程中,需要调用安全性算法函数。 ② 如果可以分配,需在屏幕上打印输出如下内容: 可以满足进程ΧΧ的资源分配请求Request[i] ... ... 。 分配后的资源分配表为: ... ... ... ... ... ... ... ... ... 否则,输出: 不能满足进程ΧΧ的资源请求Request[i] ... ... 。 ③ 返回主函数。 主函数: 假定已知T0时刻的资源分配情况,即已知可利用资源向量Available分配矩阵Allocation、最大需求矩阵Max,判断目前是否处于安全状态。如果处于安全状态,某进程进行资源申请,用银行家算法检测能否分配;否则,提示 目前系统处于不安全状态,不能再进行资源申请。 ① 进行变量定义,包括: 二维数组:Allocation、Max、Need。 一维数组:Available、Work、Finish、Request[i]。 其余变量定义根据需要指定。 ② Allocation、Max、Available的值可以从键盘输入,也可在定义时直接给定。Need值需要通过计算获得。Request[i]的值需要从键盘接收。 ③ 进行T0时刻安全性检测,调用安全性算法函数。 ④ 如果需要进行资源申请,循环调用进行银行家算法函数,直至用户要求结束或不能满足进程的资源请求为止。 实验四 页面置换算法的实现(2学时) 1、实验目的: 熟练掌握有关的存储管理算法,巩固有关存储器管理的教学内容。 2、实验任务: (1)编程实现最优置换算法OPT)算法FIFO)算法 (3)编程实现最近最久未使用(LRU)算法或简单CLOCK置换算法 3、实验要求: 任选以上两种算法进行实现。 能够根据给定的引用串及物理块数,在屏幕上输出该算法对应的置换图,及其缺页次数和缺页率。 4、设计思路和采取的方案#include #include #define M 4 #define N 17 #define Myprintf printf |+++

文档评论(0)

exianwhan + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档