进程间通信介绍
进程间通信的条件 -
进程独立
进程间通信的目的
- 数据传输:一个进程需要将他的数据发送给另一个进程
- 资源共享:多个进程之前共享同样的资源
- 通知事件:一个进程需要向另一个或者一组进程发送消息,通知他们发生了某种事件
- 进程控制:有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时通知他们状态改变
进程间通信的分类
- 管道
匿名管道 pipe
命名管道
- System V IPC
System V 消息队列
System V 共享内存
System V 信号量
- POSIX IPC
消息队列
共享内存
信号量
互斥量
条件变量
读写锁
管道
什么是管道
- 管道其实是内核提供的一段内存
- 我们把一个进程连接带另一个进程的数据流称为管道
下面以 who | wc -l 为例
匿名管道
创建一个无名管道