1.进程间通信介绍
- 进程间通信(IPC)指的是2个任意进程之间的通信。进程用户空间是相互独立的,一般而言是不能相互访问的。但很多情况下进程间需要互相通信,来完成系统的某项功能。进程通过与内核及其它进程之间的互相通信来协调它们的行为。
- 一个进程在一个地址空间中它的不同模块之间通信都是很简单的(全局变量、通过函数形参实参传递)。但是2个不同的进程处于不同的地址空间,要互相通信很难。
- 大部分程序是不需要进程间通信的,因为它们都是单进程的(可以多线程)。复杂、大型的程序(如GUI程序、服务器程序)才可能用到进程间通信,整个程序就设计成多个进程同时工作来完成的模式。
2.Linux内核提供的进程间通信机制
- 无名管道和有名管道
- SystemV IPC:信号量、消息队列、共享内存
- Socket域套接字
- 信号
3.管道
管道(一般就指无名管道)具有如下特点:
- 管道的本质就是内核维护的一块内存(内核在内存中创建一个共享文件),管道是单向通信,半双工的,它有读端和写端。
- 管道只能在父子进程间通信,父进程创建管理后fork子进程,子进程继承父进程的管道fd。
管道通信的函数:pipe、write、read、close
有名管道(实质就是可以在不是父子进程关系的而两个进程间通信的有名管道)具有如下特点:
- 有名管道实质也是内核维护的一块内存,表现形式为一个有名字的文件。它不限父子进程,任意2个进程都可。有名管道固定一个文件名,2个进程分别使用mkfifo创建fifo文件,然后分别open打开获取到fd,然后一个读一个写。
- 管道通信的函数:mkfifo、open、write、read、close
4.SystemV IPC
SystemV IPC通过一些专用API来提供进程间通信功能,分为信号量、消息队列、共享内存,其实质也是内核提供的公共内存。
消息队列
- 本质上是一个队列,队列可以理解为(内核维护的一个)FIFO。
- 工作时A和B2个进程进行通信,A向队列中放入消息,B从队列中读出消息。
信号量
- 实质就是个计数器(其实就是一个可以用来计数的变量,可以理解为int a)。
- 通过计数值来提供互斥和同步。
共享内存
- 大片内存直接映射。
- 类似于LCD显示时的显存用法。
5.剩余的2类进程间通信
1.信号
2.域套接字 socket。