进程(二):进程间通信(简单描述)

一、进程间通信

进程间通信的本质就是,让不同的进程看到同一份资源。(内存 , 文件,内核缓冲等)

1

1、为什么进程间需要通信

进程由一个pcb结构体+虚拟内存(数据段、代码段)组成,并且进程间是相互独立的。进程与进程之间的交互,就需要通过通信实现。

  • 数据传输:一个 进程需要将它的数据 发送给另一个进程。
  • 通知事件:一个进程需要向另一个或一组进程 发送消息,通知它(它们)发生了 某种事件( 如进程终止时要通知父进程)。
  • 资源共享:多个进程之间 共享同样的资源 。为了做到这一点,需要内核提供互斥和同步机制。
  • 进程控制:有些进程 希望完全控制另一个进程的执行 (如 Debug
    进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态改变。

二、进程间通信分类

在这里插入图片描述
在这里插入图片描述

1、传统间进程通信(Unix进程间通信)

无名管道(只能在亲缘进程间通信)
有名管道(任意进程间通信)
信号

2、IPC进程间通信(通过键值,键值相同则可以通信)

消息队列
共享内存(目前使用做多,效率最高)
信号量(信号灯集)(一般配合共享内存使用,实现同步与互斥,资源的占用)

3、网络进程间通信

socket

4、为什么这么多通信都要学

根据不同的需求,我们会选择不同的通信方式实现。虽然共享内存是效率最高的,使用最多的,不过也存在一些,很简单就可以实现的通信。适合的才是最好的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

好好睡觉好好吃饭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值