- 进程间通信的目的
- 数据传输:一个进程需要将它的数据发送给另一个进程
- 资源共享:多个进程之间共享同样的资源
- 通知事件:一个进程需要向另一个或一组进程发送消息,通知它(它)们发生了某种事件(如进程终止时通知父进程)。
- 进程控制:有些进程需要完全控制另一个进程的执行(Debug进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并且能够及时知道它的状态改变。
- 进程间通信发展
- 管道
- System V进程间通信
- POSIX进程间通信
- 进程间通信分类
管道- 匿名管道pipe
- 命名管道
System V IPC - System V 消息队列
- System V 共享内存
- System V 信号量
POSIX IPC - 消息队列
- 共享内存
- 信号量
- 互斥量
- 条件变量
- 读写锁
4.管道
- 管道是Unix中最古老的进程间通信的形式
- 我们把从一个进程连接到另一个进程的一个数据流称为一个“管道”
匿名管道
#include<unistd.h>
功能:创建一无名管道
原型
int pipe(int fd[2]);
参数
fd:文件描述符数组,其中fd[0]表示读端,fd[1]表示写端
返回值:成功返回0,失败返回错误代码
来源:https://blog.csdn.net/NietzscheI/article/details/100166206