1.管道:管道是Linux支持的最初Unix IPC形式之一,具备如下特色:linux
通常文件的I/O函数均可以用于管道,如close、read、write等等。web
从管道中读取数据:函数
向管道中写入数据:spa
管道可用于输入输出重定向,它将一个命令的输出直接定向到另外一个命令的输入。orm
管道的主要局限性正体如今它的特色上:对象
2.FIFO:队列
它能够运行于多个非亲属关系间交换信息。进程
FIFO的打开规则:ip
若是当前打开操做是为读而打开FIFO时,若已经有相应进程为写而打开该FIFO,则当前打开操做将成功返回;不然,可能阻塞直到有相应进程为写而打开该FIFO(当前打开操做设置了阻塞标志);或者,成功返回(当前打开操做没有设置阻塞标志)。内存
若是当前打开操做是为写而打开FIFO时,若是已经有相应进程为读而打开该FIFO,则当前打开操做将成功返回;不然,可能阻塞直到有相应进程为读而打开该FIFO(当前打开操做设置了阻塞标志);或者,返回ENXIO错误(当前打开操做没有设置阻塞标志)。
从FIFO中读取数据:
约定:若是一个进程为了从FIFO中读取数据而阻塞打开FIFO,那么称该进程内的读操做为设置了阻塞标志的读操做。
注:若是FIFO中有数据,则设置了阻塞标志的读操做不会由于FIFO中的字节数小于请求读的字节数而阻塞,此时,读操做会返回FIFO中现有的数据量。
向FIFO中写入数据:
约定:若是一个进程为了向FIFO中写入数据而阻塞打开FIFO,那么称该进程内的写操做为设置了阻塞标志的写操做。
对于设置了阻塞标志的写操做:
对于没有设置阻塞标志的写操做:
3.XSI IPc结构
他们都属于内核中的IPC结构, 它们都用标识符来描述. 这个标识符是一个非负整数, 与文件描述符不一样的是, 建立时并不会重复利用经过删除回收的整数, 而是每次+1, 直到整数最大值回转到0.
标识符是IPC对象的内部名, 而它的外部名则是key(键), 它的基本类型是key_t, 在头文件<sys/types.h>中定义为长整型. 键由内核变换成标识符.
xsi ipc缺点:消息队列和共享内存中的内容不会被自动删除;不使用文件描述符,没法使用多路转接i/o函数:select和poll
优势:可靠,流是受控的;能够用非先进先出方式处理
(1)消息队列
消息队列最大的灵活性在于,咱们能够本身定义传递给队列的消息的数据类型,消息队列比流通道稍耗内存
(2)共享内存
是一种最快的IPC
(3)信号量
在linux上,记录缩与信号量相比,多耗事60%;可是想实现简单功能,通常仍是用记录所,由于其更简单。