WindowsAPI 之 CreatePipe
时间:2015-09-06 16:16:53
收藏:0
阅读:1620
CreatePipe:创建一个匿名管道并从中得到读写句柄。
什么是管道?
在Linux中,管道是一种使用非常频繁的通信机制。从本质上说,管道也是一种文件,但它又和一般的文件有所不同,管道可以克服使用文件进行通信的两个问题,具体表现为:
· 限制管道的大小。实际上,管道是一个固定大小的缓冲区。在Linux中,该缓冲区的大小为1页,即4K字节,使得它的大小不像文件那样不加检验地增长。使用单个固定缓冲区也会带来问题,比如在写管道时可能变满,当这种情况发生时,随后对管道的write()调用将默认地被阻塞,等待某些数据被读取,以便腾出足够的空间供write()调用写。
· 读取进程也可能工作得比写进程快。当所有当前进程数据已被读取时,管道变空。当这种情况发生时,一个随后的read()调用将默认地被阻塞,等待某些数据被写入,这解决了read()调用返回文件结束的问题。
注意:从管道读数据是一次性操作,数据一旦被读,它就从管道中被抛弃,释放空间以便写更多的数据。
管道只能用于有亲缘关系进程间的通信。要实现独立进程间的通信可参照有名管道(FIFO)。
管道只能半双工通信,即某一时刻只能单向传输。要实现父子进程双方互动通信,需要定义两个管道。
/*使用pipe实现父进程向子进程发送信息*/ #include<stdio.h> #include<unistd.h> #include<stdlib.h> int main() { int fd[2]; pipe(fd);//创建管道 pid_t child; child=fork();//创建子进程 char buff[15];//子进程用于读取的缓冲区 char data[]="Hello!";//父进程用于写入的数据 if(child==-1)//出错处理 { perror("Child:"); exit(1); } else if(child==0)//子进程从管道中读取信息到buff { close(fd[1]); if(read(fd[0],buff,15)>0) { printf("pid=%d\tppid=%d\t|%s\t<Read>\n",getpid(),getppid(),buff); } close(fd[0]); exit(0); } else//父进程通过data向管道中写入信息 { close(fd[0]); if(write(fd[1],data,15)>0) { printf("pid=%d\tppid=%d\t|%s\t<Write>\n",getpid(),getppid(),data); } close(fd[1]); exit(0); } waitpid(child,NULL,0);//等待子进程结束 exit(0); }
评论(0)