什么是进程间通信?
进程是一个独立的资源分配单元,不同进程(通常指用户进程)之间的资源是独立的,没有关联,不能在一个进程中直接访问另一个进程的资源。
但进程不是孤立的,不同的进程需要进行信息的交互和状态的传递等,因此需要进程间的通信。
进程间通讯功能
- 数据传输:一个进程需要将它的数据发送给另一个进程。
- 资源共享:多个进程之间共享同样的资源。
- 通知事件:一个进程需要向另一个或一组进程发送信息,通知它们发生了某种事件。
- 进程控制:有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望能够拦截另一个进程的所有操作,并能够及时的知道它的状态改变。
管道:只能用于同一个祖先的两个进程
命名管道:可以用于不同祖先的两个进程
管道
特点
- 半双工
- 不存在文件系统,只存在内存中
- 无名,只能在公共祖先的进程间使用
- 管道的缓冲区4Kbyte