服务器
linux进程间通信——命名管道
创新互联公司坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、成都网站建设、外贸网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的西华网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!FIFO(命名管道)不同于匿名管道之处在于它提供⼀个路径名与之关联,以FIFO的⽂件形式存储于⽂件系统中。命名管道是⼀个设备⽂件,因此,即使进程与创建FIFO的进程不存在亲缘关系,只要可以访问该路径,就能够通过FIFO相互通信。值得注意的是,FIFO(first input first output)总是按照先进先出的原则⼯作,第⼀个被写⼊的数据将⾸先从管道中读出。
创建命名管道的系统函数有两个:mknod和mkfifo。两个函数均定义在头⽂件sys/stat.h,函数原型如下:
#include#include 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#include #include #include #include #include #define PATH ./fifo #define SIZE 128 int 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#include #include #include #include #include #include #include #define PATH ./fifo #define SIZE 128 int 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; }
打开两个终端:
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!