码迷,mamicode.com
首页 > 其他好文 > 详细

FIFO实现客户端服务器端通信

时间:2015-06-09 15:34:54      阅读:243      评论:0      收藏:0      [点我收藏+]

标签:


FIFO解决了在进程通信的时候产生大量临时文件的问题,并且可以实现非血缘关系进程间的通信,而且可以保留给后来的进程使用。

FIFO的读写规则和匿名管道的读写规则相似,不过FIFO保存在磁盘上,而匿名管道保存在内存里。

当FIFO的写进程关闭的时候,会向FIFO的读进程发送一个文件结束符。

客户端:

  1. #include<stdio.h>
  2. #include<unistd.h>
  3. #include<sys/stat.h>
  4. #include<sys/types.h>
  5. #include<fcntl.h>
  6. #include<string.h>
  7. int main()
  8. {
  9. char* msg = "Hello, i am client!\n";
  10. int fd = open("./fifo1",O_WRONLY);
  11. int i = 0;
  12. for(;i<10;i++)
  13. {
  14. printf(msg);
  15. if(write(fd,msg,strlen(msg)+1)<0)
  16. {
  17. _exit(-1);
  18. }
  19. sleep(2);
  20. }
  21. close(fd);
  22. return 0;
  23. }


服务器端:

  1. #include<stdio.h>
  2. #include<unistd.h>
  3. #include<sys/stat.h>
  4. #include<sys/types.h>
  5. #include<fcntl.h>
  6. #include<string.h>
  7. int main()
  8. {
  9. int fd = open("./fifo1",O_RDONLY);
  10. int i = 0;
  11. char buf[24]={0};
  12. while(read(fd,buf,24)>0)
  13. {
  14. printf(buf);
  15. }
  16. close(fd);
  17. return 0;
  18. }

技术分享




FIFO实现客户端服务器端通信

标签:

原文地址:http://www.cnblogs.com/ZhangJinkun/p/4563138.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!