文章目录
一、进程间通信
进程间通信的本质就是,让不同的进程看到同一份资源。(内存 , 文件,内核缓冲等)
1、为什么进程间需要通信
进程由一个pcb结构体+虚拟内存(数据段、代码段)组成,并且进程间是相互独立的。进程与进程之间的交互,就需要通过通信实现。
- 数据传输:一个 进程需要将它的数据 发送给另一个进程。
- 通知事件:一个进程需要向另一个或一组进程 发送消息,通知它(它们)发生了 某种事件( 如进程终止时要通知父进程)。
- 资源共享:多个进程之间 共享同样的资源 。为了做到这一点,需要内核提供互斥和同步机制。
- 进程控制:有些进程 希望完全控制另一个进程的执行 (如 Debug
进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态改变。
二、进程间通信分类
1、传统间进程通信(Unix进程间通信)
无名管道(只能在亲缘进程间通信)
有名管道(任意进程间通信)
信号
2、IPC进程间通信(通过键值,键值相同则可以通信)
消息队列
共享内存(目前使用做多,效率最高)
信号量(信号灯集)(一般配合共享内存使用,实现同步与互斥,资源的占用)
3、网络进程间通信
socket
4、为什么这么多通信都要学
根据不同的需求,我们会选择不同的通信方式实现。虽然共享内存是效率最高的,使用最多的,不过也存在一些,很简单就可以实现的通信。适合的才是最好的。