1、如何进行进程通信?(百度)(字节)(shopee)(腾讯)
1、共享存储:两个进程通过对一块共享空 间的访问实现通信。各进程对共享空间的访问是互斥的。又可以细分为基于数据结构(共享空间放一个长度为10的数组,这种共享方式比较慢,是一种低级的通信方式)、基于存储区(在内存中划一块共享储存区,数据的形式、存放位置都由进程控制,而不是OS,相比之下这种共享方式更快,是一种高级通信方式)。
**共享内存通信的优缺点:**可以解决消息队列通信带来的数据拷贝带来的开销问题。
2、消息队列传递:进程间的数据交换以格式化信息为单位,进程通过OS提供的发送消息/接收消息两个原语进行数据交换。消息队列是保存在内核中的消息链表。
- 直接通信方式:消息直接挂到接收进程的消息缓冲队列上
- 间接通信方式:消息要先发送到中间实体(信箱)中。
消息队列通信的优缺点:
首先解决了管道通信的不适合进程频繁通信的问题。但是它的缺点是:一,通信不及时。二,附件有大小的限制。三,通信过程中会存在着用户态与内核态之间的数据拷贝带来的开销。
**3、管道通信:**管道是指用于连接读写进程的一个共享文件,又名pipe,其实就是内存中开辟的一个大小固定的缓冲区。单管道只能进行半