进程间通信就是在不同进程之间传播或交换信息。根据进程通信时信息量大小的不同,可以将进程通信划分为两大类型:控制信息的通信和大批数据信息的通信。前者称为低级通信,后者称为高级通信。低级通信主要用于进程之间的同步、互斥、终止等控制信息的传递。而高级通信主要用于进程之间大量数据的传送、交换和共享。在这一节我们将介绍进程高级通信机制。常用的进程高级通信方法有共享内存区、管道通信和消息传递机制三种。
共享内存区:共享内存是一种最为高效的进程间通信方式,进程可以直接读写内存,而不需要任何数据的拷贝。为了在多个进程间交换信息,内核专门留出了一块内存区,可以由需要访问的进程将其映射到自己的私有地址空间。进程就可以直接读写这一块内存而不需要进行数据的拷贝,从而大大提高效率。由于多个进程共享一段内存,因此也需要依靠某种同步机制。共享内存的操作流程是首先创建/打开共享内存,映射共享内存,即把指定的共享内存映射到进程的地址空间用于访问,映射建立后可以像使用自身数据所在的内存空间一样对数据进行访问,数据访问后撤销共享内存映射,最后删除共享内存对象。
管道通信:管道是一种使用非常频繁的通信机制。从本质上说,管道也是一种文件,但它又和一般的文件有所不同。管道连接两个进程或者同一个进程的不同代码,按照管道的类别分为两种,匿名管道和命名管道;按照管道的传输方向分也可以分成两种,单向和双向管道。根据管道的特点,命名管道通常用在网络环境下不同计算机上运行的进程之间的通信(当然也可以用在同一台计算机的不同进程中),它可以是单向或双向的;而匿名管道只能用在同一台计算机中,它只能是单向的。使用管道的好处在于:读写它使用的是对文件操作的API,操作管道就和操作文件一样。即使你在不同的计算机之间用命名管道来通信,你也不必了解和自己去实现网络间通信的具体细节。(www.xing528.com)
消息传递机制:消息传递系统的功能是允许进程与其他进程进行通信而不必借助共享数据。用户进程之间的通信通过传递格式化的消息完成。系统提供两种操作send(message)和receive(message)来完成信息的发送和接收。消息传递系统可分为直接通信和间接通信,使用直接通信时,发送进程利用操作系统(OS)所提供的发送命令,直接把消息发送给目标进程。使用间接通信时,发送进程将消息发送到某种中间实体中(信箱),接收进程从该中间实体中取得消息,也称信箱通信。下面将对这两种通信方式进行进一步介绍。
免责声明:以上内容源自网络,版权归原作者所有,如有侵犯您的原创版权请告知,我们将尽快删除相关内容。