一些复杂的应用程序可能会需要多个进程分工协作来满足所需的功能需求,这就必然涉及到数据在进程之间的共享或交换,称 为IPC(Inter-process communication,进程间通信)。
UNIX提供了许多工具(facilities)用于实现进程间通信,这些工具可以分为三类:
通信(Communication):用于进程间交换数据。
同步(Synchronization):同步进程(或线程)之间的动作(actions)。
信号(Signals):既可以用于同步,也可以用于通信(很少使用)。
数据传输和共享内存的区别
对于数据传输工具来说,一个进程的一次读操作将消耗 (consumes)数据,即读完之后,数据对于其它进程的读操作不可 用。而放置在共享内存中的数据对于所有的进程均可见。
对于数据传输工具来说,读进程和写进程之间的同步自动完成。 而共享内存需要程序员实现同步操作。
Linux 系统的 IPC接口
Linux系统的IPC接口主要由System V IPC,POSIX IPC以及BSD Socket构成。
BSD Socket BSD Socket BSD Socket BSD Socket socket不仅可以用于同一主机上的各个进程之间的通信,更主 要的是可以用于不同主机间的网络通信。
System V IPC System V IPC System V IPC System V IPC System V IPC接口是由AT&T的贝尔实验室发展出来的,其通 信机制主要包括管道、FIFO、消息队列,信号量、共享内存等。
POSIX IPC POSIX IPC POSIX IPC POSIX IPC 由于UNIX的分支版本众多,为了提高应用程序的可移植性, IEEE制定了POSIX。POSIX IPC主要包括消息队列、信号量、共 享内存等。
主要