1.原型:int pipe(int pipefd[2]);
2.返回值:成功:0;失败:-1,设置 errno
3.函数调用成功返回 r/w 两个文件描述符。无需 open,但需手动 close。规定:fd[0] → r; fd[1] → w
4.管道创建成功以后,创建该管道的进程(父进程)同时掌握着管道的读端和写端。
5.利用pipe函数实现 ls | wc –l。假定父进程实现 ls,子进程实现 wc
6.ls | wc –l的作用是统计该路径下文件的个数
代码:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <pthread.h>
//使用管道实现父子进程间通信,完成:ls | wc –l。假定父进程实现 ls,子进程实现 wc。
//ls | wc –l的作用是统计该路径下文件的个数
void sys_err(const char *str)
{
perror(str);
exit(1);
}
int main(int argc, char *argv[])
{
int fd[2];
int ret;
pid_t pid;
//创建管道
ret = pipe(fd);
if(ret==-1) sys_err("pipe error");
pid = fork();
if(pid==-1) sys_err("fork error");
else if(pid>0){//父进程
close(fd[0]);
dup2(fd[1],STDOUT_FILENO);//将标准输出写到屏幕,改为写到管道写端
//执行execlp函数之后,ls的结果输出到了管道的写端
execlp("ls","ls",NULL); //ls默认标准输出,写到屏幕上,所以想要写到管道里,需要借助dup2函数,
//dup2函数的第一个参数是管道的写端,第二个参数是标准输出;标准输出指向管道写端,即ls写到的不是屏幕上,而是写到了管道写端
sys_err("execlp ls error");
}
else if(pid==0){
close(fd[1]);
dup2(fd[0],STDIN_FILENO);
execlp("wc","wc","-l",NULL);//wc默认是标准输入读,要实现从管道读端读,需要借助dup2,原理如上
sys_err("execlp wc error");
}
return 0;
}
结果:当前路径下有几个文件,结果就是几