进程间通讯pipe和fifo

注:fifo和pipe能够像普通的文件描述符同样读写,但不能够进行定位操做

具体参考:https://blog.csdn.net/sdkdlwk/article/details/79765676数组

mkfifo()

//建立有名管道(FIFO special file),建立完了就像普通文件同样open(),再读写,成描述符功返回0,失败返回-1设errno。VS$man 3 mkfifo #include <sys/types.h> #include <sys/stat.h> int mkfifo(const char *pathname, mode_t mode);

pathname:the FIFO special file's namespa

mode :the FIFO's permissions..net

//建立FIFO管道文件
int res=mkfifo(“./a.fifo”,0664); if(-1==res) perror("mkfifo"),exit(-1); res=open(“./a.fifo”,O_RDONLY); if(-1==res) perror(“open”),exit(-1);

pipe()

//建立无名管道,至关于直接把open()返回的fd直接放到形参中,而不需额外的变量接收管道文件的描述符,用于父子进程间经过管道进行IPC通讯,,成功返回0,失败返回-1设errno #include <unistd.h> int pipe(int pipefd[2]); //代码自注释,表示它须要的参数是一个有两个元素的数组,若是虽然做为形参,实质上和int* pipefd没有区别

pipefd :return two fds referring to the ends of the pipe.code

  • pipefd[0] :read end,读端
  • pipefd[1] :write end,读端.

fork()建立的child也会文件描述符总表也会复制一份So,对于child, 应该先关闭读端, 再写,对于parent,应该先关闭写端, 再读regexp

//使用pipe()实现父子进程的通讯 #include<unistd.h> #include<sys/types.h> #include<sys/stat.h> #include<stdlib.h> #include<stdio.h> int main(){ //1. 建立无名管道 int pipefd[2]; int res=pipe(pipefd); if(-1==res) perror("pipe"),exit(-1); //2. 建立子进程 pid_t pid=fork(); if(-1==pid) perror("fork"),exit(-1); //3. 子进程开始启动,写入1~100; if(0==pid){ close(pipefd[0]); int i=0; for(i=1;i<=100;i++){ write(pipefd[1],&i,sizeof(int)); } close(pipefd[1]);//关闭写端 exit(0); } //4. 父进程开始启动,读取管道中的数据 close(pipefd[1]); int i=0; for(i=1;i<=100;i++){ int x=0; read(pipefd[0],&x,sizeof(int)); printf("%d ",x); } printf("\n"); close(pipefd[0]); return 0; }
相关文章
相关标签/搜索