Linux并发程序设计.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文档。上传文档
查看更多
Linux并发程序设计.doc

桂 林 理 工 大 学 实 验 报 告 班级 学号 姓名 同组实验者 无 实验名称 操作系统综合实验 ---- Linux并发程序设计 日期 年 月 日 一、实验目的: 1) 通过在Linux进程之间进行的通信实例来学习并发程序设计的方法。 2) 通过Linux进程通信的程序设计与实现,进一步熟悉操作系统的进程概念,理解Linux进程管理概念。 3) 通过阅读和分析Linux实验程序,学习Linux程序设计、调试和运行的方法。要求学生能够阅读和分析本指导书的全部程序代码,并编辑、调试和运行代码,获得正确的执行结果。 二、实验环境: 一台运行 Linux操作系统的计算机。 三、实验内容: 并发程序设计的关键是使用创建进程的系统调用fork,使一个程序运行时可以生成几个同时运行的程序。 本实验中的并发程序例子完成两个程序child和father之间的数据传递工作,具体做法分为四步。 步骤1:编制并发程序pipeline.c。 单击Linux操作系统菜单中“应用程序”-“附件”-“文本编辑器”命令,在文本编辑中键入程序并保存为pipeline.c。 父进程将字符串Parent is using pipe write.写入管道,子进程从管道读出该串,子进程然后使用printf函数显示该串。 在该程序中定义管道和文件描述符,并且创建子进程child。该程序用到的系统调用有pipe() 、dup() 、fork() 、close、execl() 、exit,它们的功能分别是建立管道、复制旧的文件描述符到新的文件描述符、创建进程并使子进程与父进程有相同的程序正文、关闭文件描述符、用指定文件覆盖调用程序、撤销当前进程。 阅读程序。各种系统调用的使用方法都可以通过man 命令得到使用帮助。 清单4-1 pipeline.c // 定义管道程序 #include stdio.h #include stdlib.h #include unistd.h # define STD_INPUT 0 // 定义标准输入设备描述符指针,是linux默认的 # define STD_OUTPUT 1 // 定义标准输出设备描述符指针,是linux默认的 int fd[2]; //定义2个文件描述符指针 main( ) { static char process1[]=father,process2[]=child; //定义execl函数实参使用的父、子程序名 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) // 如果i0,是在父进程中,是父进程的返回码 { close(fd[0]); // 关闭管道输出描述符(父进程不使用fd[0]) close(STD_OUTPUT); // 关闭标准输出描述符1(原来是写到显示器的指针) dup(fd[1]); // 指定标准输出描述符1为管道写指针,以后写到标准 //输出的内容都写到fd[1]指出的文件 //dup 使用最小号码的没有使用的描述符指针作为新描述符指针 // 则:拷贝fd[1]指向的文件描述符到指针号1指向的文件描述符 close(fd[1]); // 关闭原始管道写指针 execl(process1, process1, NULL); // 调用father程序 printf( father failed.\n); // execl()执行失败才执行这一行

文档评论(0)

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

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

版权声明书
用户编号:5212202040000002

1亿VIP精品文档

相关文档