红联Linux门户
Linux帮助

Linux管道pipe使用实例

发布时间:2015-04-12 21:40:14来源:linux网站作者:ljinddlj

Moakap总结

函数

#include <unistd.h>

int pipe(int filedes[2]);

描述

pipe()函数创建一个管道和指向该管道的一对文件描述符,并且将文件描述符存储到文件描述符数组filedes[]中。其中filedes[0]为读端,filedes[1]为写端。

返回值

0 – 管道创建成功;

-1 – 管道创建失败,同时errno置位;

错误指示

EFAULT – 无效的输入参数filedes;

EMFILE – 达到当前进程允许的文件描述符最大值;

ENFILE – 达到系统允许的打开文件的最大数;


实例

下边的例子首先创建一个管道,然后通过fork()创建当先进程的子进程。接着每个进程关闭读写管道不需要的文件描述符。子进程在当前路径下执行“ls –a”命令,通过将管道写描述符fd[1]复制成标准输出,将命令执行输出写到管道;父进程通过fd[0]读取管道数据并显示。

#include <sys/wait.h>#include <assert.h>#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <string.h>int main(int argc, char *argv[]){    int fd[2];

pid_t pid;

char read_buffer[500] = {0};

int read_count = 0;

int status = 0;

//创建管道

if (pipe(fd) < 0)

{

printf("Create pipe failed.");

return -1;

}

//创建子进程

if ((pid = fork()) < 0)

{

printf("Fork failed.");

return -1;

}

//子进程操作

if (pid == 0)

{

printf("[child]Close read endpoint...");

close(fd[0]);   /* 关闭不使用的读文件描述符 */

//复制fd[1]到标准输出

if (fd[1] != STDOUT_FILENO)

{

if (dup2(fd[1], STDOUT_FILENO) != STDOUT_FILENO)

{

return -1;

}

//close fd[1],标准输出即为fd[1]

close(fd[1]);

}

//执行命令

status = system("ls –a");

if (status == -1)

{

return -1;

}

}

else

{

printf("[parent]Close write endpoint...");

//父进程读操作

close(fd[1]);   /* 关闭不使用的写文件描述符 */

//从管道读数据

read_count = read(fd[0], read_buffer, 500);

printf("Content under current directory: \n%s", read_buffer);

}

}