要让两个不同进程通信,前提条件是让两个进程看到同一资源。
对于进程间要相互通信,我们引入管道和共享内存概念
管道是Unix中最古老的进程间通信的形式,要让两个不同进程通信,前提条件是让两个进程看到同一资源。管道的生命周期是随进程的。
共享内存是进程通信中最快的,ipc的生命周期随内核,共享内存底层不提供任何的互斥机制。
一、匿名管道
匿名管道用于进程之间通信,且仅限于本地父子进程之间通信(兄弟、爷孙之间都可以,只要有亲缘关系),结构简单,类似于一根非水平状态的水管,一端进水另一端出水(单工)。相对于命名管道,其占用小实现简单,在特定情况下,比如实现两围棋引擎本地对战可以使用匿名管道。不管是匿名管道还是后面的命名管道,都只能进行单向通信,要实现双向通信,创建两个管道!
分为三步,1.创建匿名管道,以读写方式打开文件2.创建父子进程(父读子写),父关闭写子关闭读。3.父进行读,子进行写实现匿名管道通信。
(一)创建匿名管道
要创建一个匿名管道,首先我们需要一个创建函数。
功 能:创建一无名管道。 头文件:#include <unistd.h>
原 型:int pipe(int fd[2]); 函数参数是个输出型参数,相当于通过该参数将fd数组中两个值拿出来。
参 数:fd:文件描述符数组,其中fd[0]表示读端, fd[1]表示写端。
返回值:成功返回0,失败返回错误代码-1。
上图为创建一个匿名管道。关于该数组,pipefd[0]是读操作(像一个嘴巴)pipefd[1]是写操作(像一根笔)。
(二)创建父子进程(这里我们使用父读子写方式)
接着我们创建父子进程并以读写操作打开一个文件,父关闭写子关闭读。
(三)父进行读,子进行写实现匿名管道通信
#include<stdio.h>
2 #include<unistd.h>
3 #include<string.h>
4 int main()
5 {
6 int pipefd[2]={
0};//定义一个数组里边存两个变量,初始化两个变量为0
7 pipe(pipefd);//创建函数,该函数分别以读和写的方式对文件进行打开
8 pid_t id=fork();
9 //child:write
10 if(id==0)
11 {
12 close(pipefd[0]);
13 const char *msg="I am child......\n";//子进程写入该字符串
14 while(1)
15 {
16 write(pipefd[1],msg,strlen(msg));//将字符串写入打开的文件中
17 sleep(1);
18 }
19 }
20 //father:read
21 else
22 {
23 close(pipefd[1]);
24 char buffer[64];
25 while(1)
26 {
27 ssize_t s=read(pipefd[0],buffer,sizeof(buffer)-1);//第一个参数是从哪里读,第二个参数是读出来放哪里,第三个是读多少字节
28 if(s>0)//读取成功
29 {
30 buffer[s]=0;//文件是没有'\0'的&#x