本篇主要介绍linux进程间通信方式以及使用实例
进程间通信主要有以下几种方式:
1.管道(有名管道,无名管道,标准流管道)
2.设备映射
3.共享内存
4.信号量
5.消息队列
6.网络(网络通信涉及到了socket编程,下篇介绍)
双工:同一时刻,双方可以同时进行收发操作
半双工:双方可以进行收发操作,但同一时刻只能一方发,另一方收
单工:任意时刻,只能一方发,另一方收
管道
Linux管道有三种:有名管道(命名管道),无名管道(匿名管道),标准流管道。
管道是半双工的,要想全双工,必须创建两个管道。
管道遵循先入先出的原则,后写入的数据在管道末尾,先写入的数据被先读取出来。写入数据时,如果此时管道处于满的状态,则写阻塞,只有当另外一端进行读操作时,此时阻塞才会被解除,同理,读取数据时,如果此时管道为NULL的状态,则读阻塞,只有当另外一端写入数据才会解除阻塞。
管道写入之后,有数据存在,读取之后,数据不存在。
(1)无名管道(利用内核空间形成管道)
fork创建的父子进程中可以使用无名管道
操作流程:pipe->read(write)->close
#include <unistd.h>
int pipe(int pipefd[2]);
参数:
pipefd 管道描述符,pipefd[0]是读端描述符,pipefd[1]是写端描述符
返回值:
0 成功
-1 失败
实