操作系统上机练习报告.doc

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
操作系统上机练习报告

操作系统上机 实 验 报 告 成绩 教 师: 2016 年12月16日 班 级: 学 号: 姓 名: 实验一 【实验目的】 创建进程及子进程 在父子进程间实现进程通信 【实验软硬件环境】 VC++6.0 或者Linux 操作系统 【实验内容】 创建进程并显示标识等进程控制块的属性信息; 显示父子进程的通信信息和相应的应答信息。 (进程间通信机制任选) 【实验程序及分析】 在linux操作系统桌面建立test1.c程序文件如下: #includeunistd.h #includestring.h #includestdlib.h #includestdio.h main(){ char father[] = {the message is from father!}; char child[] = {the message is from child!}; int chan1[2],chan2[2]; char buff[50]; pipe(chan1); pipe(chan2); int F = fork(); printf(%d ,F); if(F0){ sleep(3); printf(this is father progress\n); close(chan1[0]);// close chan1 read close(chan2[1]);// close chan2 write write(chan1[1],father,strlen(father)); close(chan1[1]); //sleep(10); read(chan2[0],buff,50); sleep(3); printf(Father process: %s\n,buff); printf(this father process whose ID is: %d\n,getpid()); } else if (F==0){ printf(this is child progress\n); // close(chan1[1]);//close chan1 write close(chan2[0]);//close chan2 read read(chan1[0],buff,50); sleep(3); printf(Child process: %s\n,buff); write(chan2[1],child,strlen(child)); close(chan2[1]); printf(this child process whose ID is: %d\n,getpid()); printf(this child process whose fathers ID is: %d\n,getppid()); } else{creat fork() error!\n;} } 产生结果如下: 【实验心得体会】 1、通过本次实验,我认识到管道通信在进程之间的应用,了解并掌握了进程建立与通信的相关机制; 2、熟悉了Linux操作系统的一些简单操作,并体会到了Linux操作系统的设计理念。 实验 理解进程同步和互斥模型及其应用 【实验软硬件环境】 VC++6.0 或者Linux 操作系统 【实验内容】 利用通信API实现进程之间的同步: 建立司机和售票员进程; 并实现他们间的同步运行。 【实验程序及分析】 分析:司机与售票员要协同工作:一方面只有售票员把门关好之后司机才可开车,因此售票员关好门之后要通知司机开车,然后售票;另一方面,也只有司机把车停下之后售票员才能开门让乘客下车和上车,因此,此时司机应通知售票员。汽车当前正在始发站停车让乘客让乘客上车,因此,必须设置一定的信号量来实现他们之间的同步问题。 设计:设置司机与售票员的信号量为全局变量,并且客车的人数:现在人数、下车人数、上车人数为全局变量;设置司机与售票员的线程。考虑到第一站和最后一站的问题,应单独处理,故在各自的线程中分情况讨论: 具体的思路是下面的图示。其中S1是司机的信号量,S2是售

文档评论(0)

wdjp11801 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档