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; }
结果:当前路径下有几个文件,结果就是几