进程通信方式

进程通信

进程通信方式分为低级通信和高级通信两种
低级通信传递少量数据,主要用于通知对方某事件。
高级通信用于传递大量数据,信息。
低级通信的方式有信号,信号量
高级通信的方式有消息,管道和共享内存

同步通信

像打电话一样双方必须在线,同步地交谈。
管道和共享内存等都属于同步通信

异步通信

像电子邮件、短信一样不必关心对方何时接收
消息、信号属于异步通信

1、管道(匿名管道)

管道的通知机制类似于缓存,就像一个进程把数据放在某个缓存区域,然后等着另外一个进程去拿,并且是管道是单向传输的。
通信方式效率低下
管道不适合频繁通信的进程。
优点 能够保证我们的数据已经真的被其他进程拿走了

2、消息队列

通信方式也类似于缓存
如果 a 进程发送的数据占的内存比较大,并且两个进程之间的通信特别频繁的话,消息队列模型就不大适合了。因为 a 发送的数据很大的话,意味发送消息(拷贝)这个过程需要花很多时间来读内存。

3、共享内存

共享内存这个通信方式就可以很好着解决拷贝所消耗的时间了。
系统加载一个进程的时候,分配给进程的内存并不是实际物理内存,而是虚拟内存空间。那么我们可以让两个进程各自拿出一块虚拟地址空间来,然后映射到相同的物理内存中,这样,两个进程虽然有着独立的虚拟内存空间,但有一部分却是映射到相同的物理内存,这就完成了内存共享机制了。

4、信号量

共享内存最大的问题是多进程竞争内存的问题
信号量的本质就是一个计数器,用来实现进程之间的互斥与同步。

5.信号

信号是进程间可互相发送的控制信息,一般只是几个字节的数据,用于通知进程有某个事件发生。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值