linux 命名管道

来源:互联网 发布:备份与恢复软件 编辑:程序博客网 时间:2024/06/07 03:38

linux进程间通信——命名管道

  FIFO(命名管道)不同于匿名管道之处在于它提供⼀个路径名与之关联,以FIFO的⽂件形式存储于⽂件系统中。命名管道是⼀个设备⽂件,因此,即使进程与创建FIFO的进程不存在亲缘关系,只要可以访问该路径,就能够通过FIFO相互通信。值得注意的是,FIFO(first input first output)总是按照先进先出的原则⼯作,第⼀个被写⼊的数据将⾸先从管道中读出。

  创建命名管道的系统函数有两个:mknod和mkfifo。两个函数均定义在头⽂件sys/stat.h,函数原型如下:

#include <sys/types.h>#include <sys/stat.h>int mknod(const char *path,mode_t mod,dev_t dev);int mkfifo(const char *path,mode_t mode); 
   函数mknod参数中path为创建的命名管道的全路径名:mod为创建的命名管道的模式,指明其存取权限;dev为设备值,该值取决于⽂件创建的种类,它只在创建设备⽂件时才会⽤到。这两个函数调⽤成功都返回0,失败都返回-1。下⾯使⽤mknod函数创建了⼀个命名管道:

umask(0);

if (mknod("/tmp/fifo",S_IFIFO | 0666) == -1)

{

perror("mkfifo error");

exit(1);

}   

 函数mkfifo前两个参数的含义和mknod相同。下⾯是使⽤mkfifo的⽰例代码:

umask(0);

if (mkfifo("/tmp/fifo",S_IFIFO|0666) == -1)

{

perror("mkfifo error!");

exit(1);

}

下面为一个试例:

read端

#include<stdlib.h>#include<stdio.h>#include<sys/types.h>#include<sys/stat.h>#include<fcntl.h>#include<errno.h>#define PATH "./fifo"#define SIZE 128int main(){umask(0);if (mkfifo (PATH,0666|S_IFIFO) == -1){perror ("mkefifo error");    exit(0);    }int fd = open (PATH,O_RDONLY);if (fd<0){printf("open fd is error\n");return 0;}char Buf[SIZE];while(1){ssize_t s = read(fd,Buf,sizeof(Buf));if (s<0){perror("read error");exit(1);}else if (s == 0){printf("client quit! i shoud quit!\n");break;}else {Buf[s] = '\0';printf("client# %s ",Buf);fflush(stdout);}}close (fd);  return 3;}

下面为weite端:

#include<stdlib.h>#include<stdio.h>#include<unistd.h>#include<sys/types.h>#include<sys/stat.h>#include<string.h>#include<errno.h>#include<fcntl.h>#define  PATH "./fifo"#define  SIZE 128int main(){int fd = open(PATH,O_WRONLY);if (fd < 0){perror("open error");exit(0);}char Buf[SIZE];while(1){printf("please Enter#:");fflush(stdout);ssize_t s = read(0,Buf,sizeof(Buf));if (s<0){perror("read is failed");exit(1);}else if(s==0){            printf("read is closed!");return 1;}else{Buf[s]= '\0';write(fd,Buf,strlen(Buf));}}return 0;}
打开两个终端:

 




1 0
原创粉丝点击