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值。
阅读(2101) | 评论(0) | 转发(0) |