- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
进程间通信 IPC ( InterProcess Communication) Zhxg, JN56 soft, 2004.3 IPC类型 . 管道 . FIFO (命名管道) . 消息队列 . 信号量 . 共享空间 . 套接口 (可用于多台主机间的进程间通信 ) 管道 特点: • 半双工,即数据只能在一个方向上流动 • 只能在具有公共祖先的进程之间使用。通 常,一个管道由一进程调用fork,此后父、 子进程之间就可应用该管道 系统调用pipe函数创建管道 #include unistd.h int pipe(int filedes[2]); 返回:若成功则为0,若出错则为-1 经由参数filedes返回两个文件描述符, filedes[0]为读而打开, filedes[1]为写而打开。 filedes[1]的输出是filedes[0]的输入。 fork之后做什么取决于我们想要有的数据流 的方向。对于从父进程到子进程的管道,父 进程关闭管道的读端(fd[0]),子进程则关 闭写端(fd[1])。对于从子进程到父进程的 管道,父进程关闭fd[1],子进程关闭fd[0]。 下面是一个父进程通过管道向子进程传送数据的程序例子。 #include stdio.h #include stdlib.h #include unistd.h #include sys/types.h #include linux/limits.h main() { int n, fd[2]; pid_t pid; char line[PIPE_BUF]; if (pipe(fd) 0) { perror(pipe error); exit(1); } if ( (pid=fork()) 0) { perror(fork error); exit(1); } else if (pid 0) { // parent close(fd[0]); write(fd[1], hello world\n, 12); } else { // child close(fd[1]); n = read(fd[0], line, PIPE_BUF); exit(0); } write(STDOUT_FILENO, line, n); } 当管道的一端被关闭后,下列规则起作用: 1) 当读一个写端已被关闭的管道时,在所有 数据都被读取后, read返回0,以指示达到 了文件结束处。 2)如果写一个读端已被关闭的管道,则产生 信号SIGPIPE。如果忽略该信号或者捕捉 该信号并从其处理程序返回,则write出错 返回, errno设置为EPIPE。 FIFO • FIFO又称为命名管道。管道只能由相关进 程使用,它们共同的祖先进程创建了管道。 但是,通过FIFO,不相关的进程也能交换 数据。 • FIFO是一种文件类型。 stat结构成员 st_mode的编码指明文件是否是FIFO类型。 可以用S_ISFIFO宏对此进行测试。创建 FIFO类似于创建文件。 FIFO的路径名确实 存在于文件系统中。 FIFO可由库函数mkfifo创建: #include sys/types.h #include sys/stat.h int mkfifo(const char *pathname, mode_t mode); 返回:若成功则为0,出错则为-1 mode参数的规格说明与open函数中的 mode相同。 FIFO也可由系统调用mknod创建 #include sys/types.h #include sys/stat.h #include fcntl.h #include unistd.h int mknod(const char *pathname, mode_t mode, dev_t dev); 返回:若成功则为0,出错则为-1 mode参数的规格说明与open函数中的 mode相同。但必须带上S_IFIFO标志,以 说明将创建的是一个FIFO。 • 一旦已经创建了一个FIFO,就可用open打 开它。一般的文件I/O函数(close、read、 write、unlink等)都可用于FIFO。 # mknod fifo p # ls – l fifo prw-r--r-- 1 root root
文档评论(0)