操作系统实验5.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文档。上传文档
查看更多
操作系统实验5

实验5 操作系统综合实验 ----Linux并发程序设计 实验时间:90分钟 一、背景知识: 管道是Linux中最常用的进程间通信IPC inter process communication 机制。利用管道时,一个进程的输出可成为另外一个进程的输入。当输入输出的数据量特别大时,这种IPC机制非常有用。可以想象,如果没有管道机制,而必须利用文件传递大量数据时,会造成许多空间和时间上的浪费。 在Linux中,通过将两个file结构指向同一个临时的索引节点,而索引节点又指向同一个物理页而实现管道。 管道被定义为一对分开的文件描述符:一个输入和一个输出。我们可以从管道的一端写入然后从管道的另一端读取。如果定义管道的函数pipe使管道成功建立的话,pipe就会返回0,同时生成两个文件描述符。例如,如果两个文件描述符是数组myPipe[2],则myPipe[2]将会包括两个新的代表管道的输入(myPipe[1])和对管道的输出(myPipe[0])的文件描述符。 函数dup允许我们复制一个文件描述符。我们向函数传递一个已经存在了的描述符,然后它返回了一个和前面那个一模一样的新的描述符。这意味着两个描述符共享相同的结构。 程序调用fork创建一个进程,称为子进程。调用的进程称为父进程。子进程继承了父进程的几乎所有的属性,当然也具有跟父进程不同的属性。 调用fork会返回两次。返回值 0,代表子进程;返回值 0 ,代表父进程。返回值 0 ,代表error。 fork正确返回后,在父、子进程中可以直接写代码或者用execl系列函数执行应用程序。如果是用execl函数执行应用程序,且调用execl成功,那么进程会一直阻塞在execl处,执行完后直接退出进程,而不会再执行execl以后的代码。 二、实验目的 1 通过在Linux进程之间进行的通信实例来学习并发程序设计的方法。 2 通过Linux进程通信的程序设计与实现,进一步熟悉操作系统的进程概念,理解Linux进程管理概念。 3 通过阅读和分析Linux实验程序,学习Linux程序设计、调试和运行的方法。 三、实验环境 一台运行 Linux操作系统的计算机。 四、实验内容与步骤 并发程序设计的关键是使用创建进程的系统调用,使一个程序运行时可以生成几个同时运行的程序,如果程序中没有创建进程的动作则为顺序程序设计。 本实验中的并发程序例子完成两个程序child和father之间的数据传递工作,具体做法分为四步。 步骤1:编制并发程序pipeline.c。 单击红帽子,在“GNOME帮助”菜单中单击“附件”-“文本编辑器”命令,在文本编辑中键入程序并保存为pipeline.c。 在该程序中定义管道和文件描述符,并且创建子进程child。该程序用到的系统调用有pipe 、dup 、fork 、close、execl 、exit,它们的功能分别是建立管道、复制旧的文件描述符到新的文件描述符、创建进程并使子进程与父进程有相同的程序正文、关闭文件描述符、用指定文件覆盖调用程序、撤销当前进程。 阅读程序。各种系统调用的使用方法都可以通过man 命令得到使用帮助。 清单4-1 pipeline.c // 定义管道程序 #include #include #include # define STD_INPUT 0 // 定义标准输入设备描述符指针,是linux默认的 # define STD_OUTPUT 1 // 定义标准输出设备描述符指针,是linux默认的 int fd[2]; //定义2个文件描述符指针 main static char process1[] father,process2[] child; pipe fd ; // 定义管道,返回文件描述符fd[0],fd[1] // fd[1] 用来向管道中写入数据fd[0]在另一端用来读出数据 pipeline process1,process2 ; // pipeline exit 1 ; // 程序结束 pipeline char* process1,char* process2 int i; //用于创建进程的PID while i fork -1 ; // 创建进程,直到创建成功为止 if i // 父进程返回时的执行代码 close fd[0] ; // 关闭管道输出描述符(父进程不使用fd[0]) close STD_OUTPUT ; // 关闭标准输出描述符1 原来是写到显示器的指针 dup fd[1] ; // 指定标准输出描述符1为管道写指针,以后写到标准 //输出的内容都写到fd[1]指出的文件 //dup 使用最小号码的没有使用的描述符指针作为新

文档评论(0)

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

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

1亿VIP精品文档

相关文档