如何向面试官讲述进程间通信

首先不着急一上去就说通信方式,我们可以说一说为什么会有进程间通信???

因为有时候想要在两个进程之间实现数据传输、资源共享、通知事件(例如进程终止时会通知父进程)以及进程控制(debug进程可以控制其他进程的执行),但是我们知道进程组织的时候是一个结构体,进程与进程之间是相互独立的,有独立的虚拟地址空间,所以进程间通信是很难的,所以内核给我们提供一份公共资源让两进程都能访问就可以实现通信了,由此就引出了我们的几大进程间通信的方式:管道、消息队列、共享内存、信号量。接下来就是分别描述这几个方式。

管道:Linux下一切皆文件这我们必须牢记,所以管道就是一份文件,进程A能看到进程B也能够看到,
同时进程A往管道中写数据进程B就可以从另一端读数据了。管道又分为匿名管道和命名管道,匿名管
道用pipe()创建,只能用于有亲缘关系的进程间通信,而命名管道则是用于任意进程。

 命名管道的特点:
 1、适用于任意进程
 2、面向字节流
 3、半双工通信(当然想要实现全双工通信,只要两个管道就可以了)
 4、生命周期随进程
 5、内置同步与互斥机制。


消息队列:说白了消息队列就是一个链表,进程A可以向队列中写数据(写满则不能写了,
因为消息队列是固定的),队列中有数据了进程B就可以开始读数据了,读完了数据就不
能读了(这也就能说明消息队列面向数据报)

消息队列的特点:
1、适用于任意进程
2、面向数据报
3、全双工通信(只要进程有读写权限就可以双向通信)
4、生命周期随内核
5、内置同步与互斥机制。

共享内存:共享内存就是一块内存,我们知道内存有随机访问的优势ÿ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

N1314N

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

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

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

打赏作者

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

抵扣说明:

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

余额充值