pipe无名管道通信
2014-04-30 18:22
155 查看
由于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中的同一个对象,这就是为什么父子进程能通过其进行互相通信的原因。
相关文章推荐
- mkfifo函数创建有名管道
- signal信号通信
- 处理多个信号时产生的问题
- 键盘ASCII码
- 备份数据库
- MinGw与Cygwin的区别
- Git 常用命令
- JAVA当中内存管理与垃圾回收!
- 基数排序的 Java 实现
- 前m大的数
- 静态图
- Cocos2dx 3.0 过渡篇(二十三) C++11一种新随机数获取方法
- 2014年军训总结
- oracle与java的数据类型映射
- Javascript中的正则表达式
- How Many Points of Intersection? uva
- Cocos2dx 3.0 过渡篇(二十二)各种遍历与范围for语句的使用
- Cocos2dx 小技巧(三)Label的换行
- Cocos2dx 小技巧(四)delegate委托
- 回文验证