- 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
您可能关注的文档
最近下载
- 【解读】GB17761-2018电动自行车安全技术规范.pdf VIP
- AD832I机台操作指引.pdf VIP
- 《植物的茎》(教案)-中职农林牧渔大类《植物生长和环境》同步教学(高教版)(第四版)(全一册).docx VIP
- 证券从业资格证金融市场基础知识模拟卷及答案解析.docx VIP
- 证券从业资格证考试金融市场基础知识冲刺试题.docx VIP
- 证券从业资格证《金融市场基础知识》考前练习及答案解析.docx VIP
- 证券从业《金融市场基础知识》基础练及答案解析.docx VIP
- 证券从业资格考试金融市场基础知识预测试题及答案解析.docx VIP
- 2021年证券从业考试《金融市场基础知识》习题及答案.docx VIP
- 高中英语学业质量标准研究.pptx VIP
文档评论(0)