命名管道(FIFO) Linux进程进程间的通信之命名管道(FIFO)

Linux进程进程间的通信之命名管道(FIFO)
命名管道(FIFO),它和一般的管道一样。都是作为中间的邮递员来实现两个进程间的通信交流。
命名管道(FIFO)有几个特点:
1.命名管道(FIFO)是作为一种特殊的设备文件而存在。
2.通过FIFO管道不同进程间可以通过管道实现数据交流。而不像pipe只能用在有亲缘关系的进程间。
3.当使用完该管道的进程执行所有的I/O操作后,命名管道仍然存在文件系统中,以便以后继续使用。
那么我们怎么来创建一个命名管道(FIFO)呢?
1.我们可以用命令行的方式进行创建。
mkfifo 文件名 (文件名 就是我们要创建的管道)

命名管道(FIFO) Linux进程进程间的通信之命名管道(FIFO)_第1张图片

注意文件类型和颜色大小。在后面的例子我们用完后再看。
2.第二种通过系统调用使用mkfifo函数。
#include<stat.h>
#include<sys/types.h>
int mkfifo(const char * pathname ,mode_t mode);
功能:就是创建一个命名管道
返回值:成功返回0,失败返回-1。
参数: pathname 是在那个命令下创建命名管道。
mode 模式即该命名管道的权限。

下面看个例子:

#include<stdio.h>
#include<sys/stat.h>
#include<sys/types.h>
#include<stdlib.h>
#include<string.h>
#include<fcntl.h>
#include<sys/wait.h>
#include<unistd.h>
#define LEN 1024
int main(int argc ,char*argv[])
{
 int result;
 pid_t pid;
 char buf[LEN];
 int fd,flag=0;

 unlink("fifo");
 result=mkfifo("fifo",0777);//创建的命名管道为755
 if(result==-1){
  perror("mkfifo error:");// print a system error message
  exit(EXIT_FAILURE);
 }
 if((pid=fork())==-1){//创建一个子进程
  perror("fork  error:");
  exit(EXIT_FAILURE);
 }else if(pid==0){//子进程

  fd=open("fifo",O_RDONLY);  
          //以只读的方式打开刚才创建的命名管道
  while(1){
   read(fd,buf,LEN);//读取命名管道中的数据放到buf中
   printf("read from pipe:  %s\n",buf);
   if(strcmp(buf,"exit")==0){//if读到的字符串为exit则退出
    exit(EXIT_SUCCESS);
   }
  }

 }else{//父进程

  fd=open("fifo",O_WRONLY);    
            //以只读的方式打开刚才创建的命名管道          
  while(1){
   waitpid(pid,NULL,WNOHANG);
          //等待子进程退出父进程用来回收资源等
   if(flag==1){
    exit(EXIT_SUCCESS);
    close(fd);
   }
   scanf("%s",buf);
   write(fd,buf,strlen(buf)+1);    
                  //向管道中写入数据      
   if(strcmp(buf,"exit")==0){
    flag=1;//退出标志
    sleep(1);//保证子进程先退出
   }

  }
 }

 return 0;
}

运行结果为:

可以看出管道文件fifo的大小还是o,它只是中间介质。用来实先进程间通信的工具。

 

你可能感兴趣的:(linux,null,System,工具)