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


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

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

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

客户端:

 
     
  1. #include
  2. #include
  3. #include
  4. #include
  5. #include
  6. #include
  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
  2. #include
  3. #include
  4. #include
  5. #include
  6. #include
  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实现客户端服务器端通信_第1张图片


来自为知笔记(Wiz)


转载于:https://www.cnblogs.com/ZhangJinkun/p/4563138.html

你可能感兴趣的:(FIFO实现客户端服务器端通信)