进程间的五种通信方式(IPC):
1、管道(无名管道),速度慢,容量有限,只有父子进程能通讯;2、FIFO(命名管道),任何进程间都能通讯,但速度慢;3、消息队列,容量受到系统限制;4、信号量,不能传递复杂消息,只能用来同步;5、共享内存区。
一、管道:
管道:通常指无名管道,是UNIX系统中IPC最古老的形式。
1.特点:
它是半双工的(即数据只能在一个方向上流动),具有固定的读端和写端。
它只能用于具有亲缘关系的进程之间的通信(也是父子进程或者兄弟进程之间)。
它可以看成是一种特殊的文件,对于它的读写也可以使用普通的read、write 等函数。但是它不是普通的文件,并不属于其他任何文件系统,并且只存在于内存中。
2.原型:
#include <unistd.h>
int pipe(int pipefd[2]);
当一个管道被创建时,它会伴随着创建两个文件描述符,fd[0]
为读而打开,fd[1]
为写而打开。
如下图所示:
想关闭管道只要将两个文件描述符关闭即可。
3.用例说明:
单个进程中的管道几乎是没意义的,所以在调用pipe创建管道的时候,接着就调用函数fork()创建子进程,这样就实现了父进程与子进程之间的IPC方式。
(1)在使用fork()之后的半双工通信管道
(2)简单的从父进程到子进程之间的通信管道
直接上代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
int main()
{
//int pipe(int pipefd[2]);
int fd[2];
int pid;
char *wbuf = "hello word!";
char *rbuf = NULL;
if(pipe(fd) == -1)
{
printf("creat pipe error!\n");
}
pid = fork();
if(pid < 0)
{
printf("creat Process error!\n");
}
else if(pid > 0)
{
sleep(3);
printf("this is father process!\n");
close(fd[0