Linux进程通信(一)
一、什么是进程通信
通俗的讲进程通信就是指在进程间传输数据(交换信息)。
二、进程通信的原理
每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷到内核缓冲区,进程2再从内核缓冲区把数据读走,内核提供的这种机制称为进程间通信机制。
三、管道通信
3.1管道简介
管道是Linux中进程通信的一种方式,它把一个程序的输出直接连接到另一个程序的输入。Linux的管道主要包括两种:无名管道和有名管道。
3.1.1无名管道
函数形式:int pipe(int fd[2])
功能:创建无名管道文件。无名管道是一个特殊文件,不可由open函数创建。
参数:fd[2]有两个成员 fd[0]和 fd[1],他们都是文件描述符。 管道有固定的读端 fd[0]和固定的写端 fd[1]。
返回值:成功返回 0,出错返回-1。
特点:
(1)只能用于具有亲缘关系的进程之间的通信。
(2)是一个单工的通信模式,有固定的读端和写端。
(3)管道也可以看成一种特殊的文件,对于它的读写也可以使用普通的read(),write()等函数。但是它不属于任何文件系统