原因
每个进程有自己独立地地址空间。在操作系统和硬件的地址保护机制下,进程无法访问其他进程的地址空间,所以必须借助于操作系统的系统调用函数实现进程之间的通信。
进程通信的主要方式
(1)共享内存区。通过系统调用创建共享内存区。多个进程可以(通过系统调用)连接同一个共享内存区,通过访问共享内存区实现进程之间的数据交换。使用共享内存区时需要利用信息量解决同步互斥问题。
(2)消息传递。通过发送/接收消息(两个系统调用)来实现进程之间的通信。当进程发送时,系统将消息从用户缓冲区复制到内核中的消息缓冲区,然后将消息缓冲区挂入消息队列。进程发送的消息保持在消息队列中,直到被另一进程接收。当进程接收消息时,系统从消息队列中解挂消息缓冲区,将消息从内核的消息缓冲区中恢复到用户缓冲区,然后释放消息缓冲区。
(3)管道系统。管道是先进先出的信息流,允许多个进程向管道写入数据,允许多个进程从管道读出数据。在读/写过程中,操作系统保证数据的写入顺序和顺序是一致的。(即发送数据和受到的数据在组织上是一致的,如:发送asd,收到asd,不会收到乱序的das等)进程通过读/写管道文件或者管道设备实现彼此的通信。
(4)共享文件。利用操作系统提供的文件共享功能实现进程之间的通信。这个时候,也需要信号量来解决文件共享操作中的同步和互斥问题。