双向FIFO

时间:2010-04-27 15:00:31

标签: c fifo

我想实现双向fifo。下面的代码正在运行,但它没有使用双向fifo。我在互联网上搜索过,但没有找到任何好的例子......

我该怎么做?

谢谢,

WRITER.c:

#include <stdio.h>

#include <unistd.h>

#include <string.h>

#include <sys/types.h>

#include <sys/wait.h>
#include <fcntl.h>



#define MAXLINE 4096

#define READ 0

#define WRITE 1


int main (int argc, char** argv)
{
 int a, b, fd;

 do {
   fd=open("/tmp/myfifo",O_WRONLY);
   if (fd==-1) sleep(1);
  } while (fd==-1);

  while (1) {
   scanf("%d", &a);
   scanf("%d", &b);

   write(fd,&a,sizeof(int));
   write(fd,&b,sizeof(int));

   if (a == 0 && b == 0)
   {
    break;
   }

  }

  close(fd);
  return 0;
}

READER.c:

#include <stdio.h>

#include <unistd.h>

#include <string.h>

#include <sys/types.h>

#include <sys/wait.h>
#include <fcntl.h>
#include <sys/stat.h>




#define MAXLINE 4096

#define READ 0

#define WRITE 1



int main(void)

{
  int n1, n2;
  int fd;

  mkfifo("/tmp/myfifo",0660);
  fd=open("/tmp/myfifo",O_RDONLY);

  while(read(fd, &n1, sizeof(int) ))
  {
 read(fd, &n2, sizeof(int));

 if (n1 == 0 && n2 == 0)
 {
  break;
 }

 printf("soma: %d\n",n1+n2);

  printf("diferenca: %d\n", n1-n2);

   printf("divisao: %f\n", n1/(double)n2);

   printf("multiplicacao: %d\n", n1*n2); 
  }

  close(fd);

  return 0;
}

3 个答案:

答案 0 :(得分:10)

FIFO往往是单向的。如果你想要一个FIFO,你可以读取和写入,你真正想要的可能是一对FIFO(每个方向一个)或UNIX套接字。

答案 1 :(得分:3)

FIFO(也称为命名管道)提供单向进程间通信通道。 FIFO具有读端和写端。写入FIFO写入端的数据可以从FIFO的读端读取。因为它们是单向的,所以双向通信需要一对FIFO。

作为cHao suggested,另一种选择是使用Unix套接字。 Unix域套接字比FIFO设置(套接字创建,初始化和连接)需要更多的开销,但更灵活并提供双向通信。

答案 2 :(得分:0)

另一种选择是使用psudo-terminal(ptty)。您也可以使用TCP套接字,它比UNIX套接字具有更高的开销,但可以工作。

经常不鼓励使用双向管道,因为可能会出现死锁(prog1正在等待来自prog2的数据,等待来自prog1的数据,等待来自prog2的数据...),但这可能发生在任何变通方法中同时,也可以使用SMTP(简单邮件传输协议)等常用协议,因为每一方都在对话中发挥作用。

如果您认为可能发生死锁,您可能希望至少有一方有超时,您可以通过其中一个轮询功能(包括poll,select,pselect和epoll_ *)或安排要发送的SIGALM(带有警报或一些其他功能,允许更短的时间和更多的控制),以便您的程序可以摆脱僵局。