由于fork创建子进程与父进程拥有相同的虚拟存储器,所以在父子进程写相应段之前,写时拷贝没有出现,存储器映射到同一段物理内存。从而子进程拥有父进程的所有上下文场景:
如全局与局部变量、打开的文件句柄,共享内存、消息等同步对象等。
pipe创建了2个文件句柄,在调用fork后,文件句柄被复制进了子进程中,由于上诉黑体字,在子进程对管道的操作与在父进程中相通。
如:
pipe产生句柄pipe[0],pipe[1],则在父子进程中都有这两个句柄。
通常的做法是在父进程中关闭pipe[0]用pipe[1]写入,相应的子进程则关闭pipe[1]用pipe[0]读出
;在父进程中关闭pipe[1]用pipe[0]读取,相应的子进程则关闭pipe[0]用pipe[1]写入。
pipe[0]:管道读取端
pipe[1]:管道写入端
关于进程间信息的传递:
pipe匿名管道和文件,socket等一样是属于操作系统的管理对象,对其进行读写都是由OS的内核代码来进行控制的。在父进程调用pipe创建出管道后,该管道对象是存储在OS内部的,父进程得到的pipe[0]和pipe[1]都只是对该对象的引用(相当于指针);在fork出子进程后,子进程复制出的也只是同一个指针,所指向的还是OS中的同一个对象,这就是为什么父子进程能通过其进行互相通信的原因。
如全局与局部变量、打开的文件句柄,共享内存、消息等同步对象等。
pipe创建了2个文件句柄,在调用fork后,文件句柄被复制进了子进程中,由于上诉黑体字,在子进程对管道的操作与在父进程中相通。
如:
pipe产生句柄pipe[0],pipe[1],则在父子进程中都有这两个句柄。
通常的做法是在父进程中关闭pipe[0]用pipe[1]写入,相应的子进程则关闭pipe[1]用pipe[0]读出
;在父进程中关闭pipe[1]用pipe[0]读取,相应的子进程则关闭pipe[0]用pipe[1]写入。
pipe[0]:管道读取端
pipe[1]:管道写入端
关于进程间信息的传递:
pipe匿名管道和文件,socket等一样是属于操作系统的管理对象,对其进行读写都是由OS的内核代码来进行控制的。在父进程调用pipe创建出管道后,该管道对象是存储在OS内部的,父进程得到的pipe[0]和pipe[1]都只是对该对象的引用(相当于指针);在fork出子进程后,子进程复制出的也只是同一个指针,所指向的还是OS中的同一个对象,这就是为什么父子进程能通过其进行互相通信的原因。