`
sealbird
  • 浏览: 586585 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

UNIX管道编程——使用pipe函数,dup函数,dup2函数

    博客分类:
  • C++
阅读更多
2009-12-29 11:46管道在unix类系统中是一个很重要的概念,文件的重定向就是使用管道来实现的,在shell中也提供了"|"来直接使用管道,那么在C中,如何使用管道呢?

管道在unix中是通过pipe函数来实现的。

头文件: #include <unistd.h>
函数定义:int pipe(int filedes[2]);
函数说明:
函数返回文件描述符,其中filedes[0]为管道的写入端,filedes[1]为管道的读取端


函数实例(一)pipe的简单使用:
#include <unistd.h>
#include <stdio.h>

int main( void )
{
int filedes[2];
char buf[80];
pid_t pid;

pipe( filedes );

if ( (pid=fork()) > 0 )
{
printf( "This is in the father process,here write a string to the pipe.\n" );
char s[] = "Hello world , this is write by pipe.\n";
write( filedes[1], s, sizeof(s) );
close( filedes[0] );
close( filedes[1] );
}
else
{
printf( "This is in the child process,here read a string from the pipe.\n" );
read( filedes[0], buf, sizeof(buf) );
printf( "%s\n", buf );
close( filedes[0] );
close( filedes[1] );
}

waitpid( pid, NULL, 0 );

return 0;
}

函数输出结果:

This is in the child process,here read a string from the pipe.
This is in the father process,here write a string to the pipe.
Hello world , this is write by pipe.

函数实例(二)使用dups文件重定向和父子进程的数据交互:
在shell命令下输入:
#cat file | grep "string"
grep 命令将使用cat命令的输出作为自己的输入,这个就是简单的用管道实现文件重定向的例子。
为了实现父子进程间的管道,我们需要将父进程的标准输出重定向到管道的输入端,将子进程的标准输入重定向到管道的标准输出端,这样父进程的输出就可以作为子进程的输入来使用了。

实现文件重定向:
只需要将管道的输入端(输出端)复制到文件描述符0(1)即可

  dup2(fd1, 0);   /* 复制fd1到文件描述符0中,更改标准输入为fd1,这里fd1应为管道的输入端 */

  dup2(fd2, 1);   /* 复制fd2到文件描述符1中,更改标准输出为fd2,这里fd2应为管道的输出端 */

  dup2(fd3, 2);   /* 复制fd3到文件描述符2中,更改标准错误输出为fd3 */

看一个例子:

#include <unistd.h>
#include <stdio.h>
int main()
{
int fildes[2];
pid_t pid;
int i, j;
char buf[256];
if (pipe(fildes) < 0 || (pid = fork()) < 0) /* 创建管道和子进程 */
{
fprintf(stderr, "error!n");
return 1;
}
if (pid == 0)
    {
close(fildes[1]);                   
dup2(fildes[0], 0);                
close(fildes[0]);
gets(buf);                        
fprintf(stderr, "child:[%s]n", buf);
return 2;
}
close(fildes[0]);
dup2(fildes[1], 1);                  
close(fildes[1]);
puts("Hello!");                       
return 0;                           
}

在上例中,父进程的输出被重定向到管道输入端,子进程从管道的输出端读数据。 
分享到:
评论

相关推荐

    unix环境高级编程-函数原型.pdf

    这一部分包含了许多基础的系统操作,如文件操作、进程管理、内存管理等函数原型,如 dup()、dup2()、pipe() 等。 3. 库调用(Section 3): 库调用指的是定义在程序库中的函数,它们是封装好的函数集合,提供了更...

    linux/unix系统编程手册附录代码

    《Linux/Unix系统编程手册》是一本深受程序员和系统管理员喜爱的经典著作,它详细阐述了在Linux和Unix操作系统上进行低级编程的各种技术。附录中的代码是书中的实例,旨在帮助读者深入理解和掌握这些系统编程的核心...

    UNIX环境高级编程第二版 中文版 PDF

    - **进程间通信(IPC)**:包括管道(pipe)、命名管道(fifo)、消息队列(msg)、共享内存(shm)和信号量(sem)等机制。 - **线程管理**:讲解pthread库的使用方法,包括线程的创建(pthread_create)、同步(pthread_mutex)...

    UNIX系统编程code

    9. **管道和FIFO**:`pipe()`, `mkfifo()`, `read()`, `write()`用于创建和使用管道和FIFO(先进先出队列),实现简单进程间通信。 10. **标准输入/输出和重定向**:UNIX的`stdin`, `stdout`, `stderr`是预定义的...

    unix环境高级编程第三版随书例子程序

    2. **标准输入输出**:如何重定向标准输入、输出和错误流,以及使用dup和dup2函数创建多个文件描述符指向同一文件或管道。 3. **进程管理**:涵盖fork、exec家族(如execlp、execv、execve等)、waitpid和wait,...

    UNIX环境高级编程书中源代码

    4. **进程间通信(IPC)**:UNIX提供了多种进程间通信方式,如管道(pipe)、套接字(socket)、消息队列、共享内存和信号量。源代码可能会展示如何使用这些机制实现进程间的协作。 5. **目录和文件系统操作**:如`...

    编程高手 笔记 通过管道与子进程通信

    使用`dup2()`函数可以将管道的文件描述符重定向到标准输入(`STDIN_FILENO`)和标准输出(`STDOUT_FILENO`)。这使得子进程的输出可以被父进程读取,反之亦然。在`parent.c`中,父进程将`parent_to_child[0]`重定向到...

    进程间通信——匿名管道

    4. 将读端文件描述符通过 dup2() 或者 execlp() 等函数传递给子进程,使得子进程可以读取管道中的数据。 5. 子进程关闭读端文件描述符,避免不必要的资源浪费。 6. 父进程和子进程分别通过写端和读端文件描述符进行...

    ch06unix-linux编程实践.rar

    这一章会介绍如何使用文件描述符和`dup()`、`dup2()`等函数实现输入输出重定向。 5. **信号处理**:Unix/Linux通过信号来传递异步事件的通知。学习如何注册信号处理函数和处理常见的信号如SIGINT(中断)、SIGTERM...

    好的UNIX程序例子

    创建管道使用`pipe()`函数,然后通过`dup2()`或`fork()`将管道的读写端口连接到进程的标准输入/输出。这种方式常用于简单地将一个程序的输出作为另一个程序的输入,比如`ls | sort`命令,其中`ls`的输出被`sort`作为...

    IO-example.rar_io函数调用

    此外,可能会使用`dup2()`函数将管道的文件描述符替换为标准输入、输出或错误,以便于数据传输。 总的来说,这个压缩包提供了一个学习C语言IO函数和管道通信的实践案例,涵盖了从基本的文件操作到进程间通信的重要...

    UNIX环境高级编程(中文版+英文版+源代码)

    - 进程间通信(IPC):包括管道(pipe)、消息队列、共享内存、套接字等机制。 2. **文件与I/O系统**: - 文件描述符:如何打开、关闭文件,以及`dup()`和`dup2()`的用途。 - 文件读写:`read()`, `write()`,...

    Unix-Linux编程实践教程.rar

    了解如何重定向I/O流,使用`dup`、`pipe`和`fifo`等机制是高效编程的关键。 5. **网络编程**:Unix/Linux提供了强大的网络编程接口,如socket API,支持TCP/IP协议族,使得开发者能够创建服务器和客户端应用,进行...

    Linux进程的管道通信

    下面是一个简单的示例代码,展示了如何使用管道在父进程和子进程中进行通信: ```c #include #include #include #define syserr(str) { perror(str); exit(1); } int main() { int pfd[2]; char fdstr[10]; ...

    UNIX环境高级编程881

    `dup`函数可以复制一个已存在的文件描述符,而`close`函数则用于关闭不再使用的文件。 **二、标准I/O库** 标准I/O库提供了一组C语言的输入/输出函数,如`fopen`、`fclose`、`fprintf`等,它们基于缓冲区,简化了...

    Unix程序设计课件

    创建管道用pipe()函数,然后通过dup2()重定向文件描述符以实现数据流。 通过学习这个课件,你不仅可以掌握Unix编程的基本技能,还能了解到如何利用Unix的工具和API构建复杂的应用程序。这将有助于你在软件开发、...

    Unix_API.rar

    7. 其他功能:如pipe()和fifo()用于创建管道进行进程间的通信,dup()和dup2()用于复制或重定向文件描述符,pthread_系列函数用于多线程编程。 了解和熟练掌握Unix API对于开发跨平台的应用程序至关重要,因为它不仅...

    管道通信非常好

    例如,可以调用`system`函数执行操作系统级别的管道命令,或者编写C/C++程序作为MEX文件,利用C语言中的管道API(如`pipe`, `fork`, `dup2`等)来实现进程间通信。 下面是一些使用MATLAB进行管道通信的示例: 1. *...

    北邮 蒋砚军 unix(2)

    本次实验的核心任务是使用特定的系统调用(如`fork()`、`exec()`、`dup2()`、`pipe()`、`open()`)来模拟一条Shell命令的功能。具体而言,该Shell命令为:`grep –v usr | wc –l &gt; result.txt`。 #### 知识点解析 ...

Global site tag (gtag.js) - Google Analytics