利用有名管道实现进程间的通信

 1 /*****************************************************************
  2 *   Copyright (C) 2018 FBI WARNING. All rights reserved.
  3 *   
  4 *   文件名称:fifo_write.c
  5 *   创 建 者:constantine
  6 *   创建日期:2018年02月26日
  7 *   描    述:
  8 *
  9 *****************************************************************/
 10 
 11 #include 
 12 #include 
 13 #include 
 14 #include 
 15 #include 
 16 #include 
 17 #include 
 18 #include 
 19 
 20 int main()
 21 {
 22     int ret,fd;
 23     char buf[100]={0};
 24     ret = mkfifo("fifo.tmp",O_CREAT | O_EXCL);
 25     if(-1 == ret)
 26     {
 27         perror("mkfifo");
 28         exit(1);
 29 
 30     }

上面是写的一端下面是读的一端


/*****************************************************************
*   Copyright (C) 2018 FBI WARNING. All rights reserved.
*   
*   文件名称:fifo_read.c
*   创 建 者:constantine
*   创建日期:2018年02月26日
*   描    述:
*
*****************************************************************/

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 



int main()
{
	int ret;
	char buf[100] = {0};
	int fd = open("fifo.tmp",O_RDONLY);
	if(-1 == fd)
	{
		perror("read");
		exit(1);

	}
	while(1)
	{
		ret = read(fd,buf,sizeof(buf));
		if(-1 == ret)
		{
			 perror("read");
			 exit(1);
		}
		if(!strcmp(buf,"bye"))
		{
		  break;
		}
		printf("read from buf: %s\n",buf);
		memset(buf,0,sizeof(buf));
	}

	return 0;

}

你可能感兴趣的:(利用有名管道实现进程间的通信)