您的位置:首页 > 运维架构 > Linux

Linux进程间的通信--管道通信

2016-10-24 23:00 225 查看
管道通信

·管道是单向的、先进先出的,它把一个进程的输出和另一个进程的输入连接在一起。

·一个进程(写进程)在管道的尾部写入数据,另一个进程(读进程)从管道的头部读出数据

·数据被一个进程读出后,将被从管道中删除,其它读进程将不能再读到这些数据。

·管道提供了简单的流控制机制,进程试图读空管道时,进程将阻塞。同样,管道已经满时,进程再试图向管道写入数据,进程将阻塞

    

无名管道:

1.pipe

函数的原型:int pipe(int fds[2])

函数的参数:新建的两个描述符fds数组返回,fds[0]表示管道的读取端,fds[1]表示管道的写入端。

返 回 值:成功0,出错-1

头 文 件:#include <unistd.h>

 

管道读写:

1.先创建管道pipe;

2.fork创建子进程

[html] view
plain copy

 





#include <unistd.h>  

#include <errno.h>  

#include <stdio.h>  

#include <stdlib.h>  

   

int main()  

{  

int pipe_fd[2];  

if(pipe(pipe_fd)<0)  

{  

printf("pipe create error\n");  

return -1;  

}  

else  

printf("pipe create success\n");  

close(pipe_fd[0]);  

close(pipe_fd[1]);  

}  

 

有名管道:

·创建管道mkfifo

·打开管道open

·读管道read

·写管道write

·关闭管道close

·删除管道unlink

 

2.mkfifo

函数的作用:创建有名管道

函数的原型:int mkfifo(const char * filename,mode_t mode)

参数的作用:filename:有名管道的路径、名称

            mode:打开管道的方式

             O_NONBLOCK:  FIFO打开的时候,费阻塞

             O_RDONLY:  只读

             O_WRONLY:  只写

             O_RDWR:  可读写

返 回 值:成功 0    出错 -1
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: