1.原型:int pipe(int pipefd[2]);
2.返回值:成功:0;失败:-1,设置 errno
3.函数调用成功返回 r/w 两个文件描述符。无需 open,但需手动 close。规定:fd[0] → r; fd[1] → w
4.管道创建成功以后,创建该管道的进程(父进程)同时掌握着管道的读端和写端。
5.利用pipe函数实现兄弟进程间通信
代码:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <pthread.h>
#include <sys/types.h>
#include <sys/wait.h>
void sys_err(const char * str)
{
perror(str);
exit(1);
}
//兄弟进程之间的通信与父子进程之间通信的区别是:
//父子进程间通信只要父进程关闭读端,子进程关闭写端就行了
//兄弟进程间通信间不仅要兄进程关闭读端,弟进程关闭写端,还要父进程关闭读端和写端,保证管道的单向流通
int main()
{
int fd[2];
pid_t pid;
int ret;
int n = 2;
//创建管道
ret = pipe(fd);
if(ret==-1) sys_err("pipe error");
int i;
for(i=0;i<n;i++){
pid = fork();
if(pid==-1) sys_err("fork error");
else if(pid == 0) break;
else{
printf("I'm parent\n");
}
}
if(i==0){//子进程1,执行 ls ,关闭管道的读端fd[0]
close(fd[0]);
dup2(fd[1],STDOUT_FILENO);
execlp("ls","ls",NULL);
sys_err("execlp ls error");
}
if(i==1){//子进程2,执行 wc -l ,关闭管道的写端fd[1]
close(fd[1]);
dup2(fd[0],STDIN_FILENO);
execlp("wc","wc","-l",NULL);
sys_err("execlp wc error");
}
if(i==n){//父进程
close(fd[0]);
close(fd[1]);
wait(NULL);
wait(NULL);
}
return 0;
}
结果: