进程间通信 | 描述 |
环境变量/文件描述符 | 子进程接受父进程环境数据的拷贝以及所有文件描述符。父进程可以在它的数据片断或环境中设置一定的变量,同时子进程接收这些值。父进程可以打开文件,同时推进读/写指针的位置,而且子进程使用相同的偏移访问该文件。 |
命令行参数 | 在调用exec或派生函数期间,命令行参数可以传递给子进程。 |
管道 | 用于相关和无关进程间的通信,而且形成两个进程间的一个通信通道,通常使用文件读写程序访问。 |
共享内存(动态数据交换,Dynamic data exchange) | 使用客户机/服务器模型(C/S),服务器对客户的数据或动作请求作出反应。 |
DDE | 两个进程之外的内存块,两个进程均可以访问它。 |
当创建一个子进程时,它接受了父进程许多资源的拷贝。子进程接受了父进程的文本、堆栈
以及数据片断的拷贝。子进程也接受了父进程的环境数据以及所有文件描述符的拷贝。子进
程从父进程继承资源的过程创造了进程间通信的一个机会。父进程可以在它的数据片断或环
境中设置一定的变量,子进程于是接受这些值。同样,父进程也可以打开一个文件,推进到
文件内的期望位置,子进程接着就可以在父进程离开读/写指针的准确位置访问该文件。
这类通信的缺陷在于它是单向的、一次性的通信。也就是说,除了文件描述外,如果子进程
继承了任何其它数据,也仅仅是父进程拷贝的所有数据。 一旦创建了子进程,由子进程对
这些变量的任何改变都不会反映到父进程的数据中。同样,创建子进程后,对父进程数据的
任何改变也不会反映到子进程中。所以,这种类型的进程间通信更像指挥棒传递。一旦父进
程传递了某些资源的拷贝,子进程对它的使用就是独立的,必须使用原始传递资源。
二、命令行参数:
通过命令行参数(command-line argument)可以完成另一种单向、一次性的进程间通信
我前面的文章已经提到过使用命令行参数。命令行参数在调用一个exec或派生调用操作系
统时传递给子进程。命令行参数通常在其中一个参数中作为NULL终止字符串传递给exec
或派生函数调用。这些函数可以按单向、一次性方式给子进程传递值。WINDOWS有调用执行
exe程序的API。大家可以去参考一下ShellExecuteA函数相关。
三、管道通信:
继承资源以及命令行参数是最简单形式的进程间通信。它们同时有两个主要限制。除了文件
描述符外,继承资源是IPC的单向、一次性形式。传递命令参数也是单向、一次性的IPC
方法。这些方法也只有限制于关联进程,如果不关联,命令行参数和继承资源不能使用。还
有另一种结构,称做管道(Pipe),它可以用于在关联进程间以及无关联进程间进行通信。
管道是一种数据结构,像一个序列化文件一样访问。它形成了两个进程间的一种通信渠道。
管道结构通过使用文本和写方式来访问。如果进程A希望通过管道发送数据给进程B,那么
进程A向管道写入数据。为了让进程B接收此数据,进程B必须读取管道,与命令行参数的
IPC形式不一样。管道可以双向通信。两进程间的数据流是双向通信的。管道可以在程序的
整个执行期间使用,在进程间发送和接收数据。所以,管道充当可访问管道的进程间的一种
可活链接,有两种基本管道类型:
1. 匿名管道
2. 命名管道
上面的图可以看出在没有管道时,两进程是不能互写的。
建立管道后就可以相互通信了。
欢迎光临 电子技术论坛_中国专业的电子工程师学习交流社区-中电网技术论坛 (http://bbs.eccn.com/) | Powered by Discuz! 7.0.0 |