linux系统IPC浅谈

IPC作为进程间通讯的重要工具,被分为管道(无名管道),FIFO(又名管道),共享内存,信号量和消息队列。

1. 管道(pipe):我们一般提到的管道默认是无名管道,有以下几个特点:

-> a. 管道具有单向性(半双功性),即管道只能单方向传送信息,每一个管道含有两个端(读端和写端),在信息传送时我们只能选择>其中一个打开。
-> b. 管道只能在父子进程或者兄弟进程之间使用,在独立进程之间无效。
-> c. 管道传输数据大小有限制
-> d. 管道在没人启用时会清空,如果有人读了管道中数据,数据也会消失,即一次性。

2. FIFO:FIFO即为有名管道,是将信息当作文件来用,读写方式等等大致与文件相同,但有不同于文件,FIFO不可存储离线数据。
  
3. 共享内存:共享内存无互斥,多用于多进程之间的大块数据的传递。其独立于进程,只要拥有key有权限就可以通过shmget得到。

-> a. 共享内存是一段连续的一位的现行空间。
-> b. 共享内存需要主动清除信息才可消失,即使程序宕掉,共享内存中数据也会保留。
-> c. 当程序重起时,还可以延续上次的数据,意味着在一个进程出现故障被迫停止时,修复故障后还是可以借助共享内存中的信息>接着故障之前继续执行而不必重新开始。
-> d. 谁要用共享内存必须自己attach,别人attach的你用不了,每次attach的结果不一样,attach在一个进程中只需执行一次,之>后该进程中一直有效。

4. 信号量:信号量携带的信息几乎为零,但是由于其拥有原子特性且全系统全局,所以常被我们用作锁。
   
-> a. 我们可以将信号量看作一种全系统的全局变量,但由于其操作安全,又不同于全局变量。
-> b. 信号量本身是一种计数器,小于256且关于0对称。
-> c. 信号量和资源本身之间没有必然联系。
-> d. 原子操作代价较大,只能串行操作。
-> e. 信号量是系统内核资源,需要内核调用。
-> f. 信号量值如果设为1,他就是一把互斥锁。
     --> 能不用互斥尽量不用互斥,如果非得用互斥的话,尽量减少互斥区间,即临界区越小越好。

5. 消息队列:消息队列将数据分为一条条传递,不再使用大块内存,每个消息有一个报头,推测为一个数组。
 
-> a. 消息队列在操作时也是原子操作。
-> b. 消息的收发具有一次性,如果一条消息有100个字节,而你在收取时只接收了50个字节,那么剩余50个字节将被丢弃。
-> c. 消息队列通过条数和每一条消息的字节数同时控制。由于容器容量一定,消息队列的消息条数取决于消息的大小。
-> e. 每一条消息都有一个long类型的种类编号,即type值。
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值