2

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

我怎样才能做到这一点?

谢谢,

作家.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;
}

读者.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;
}
4

3 回答 3

15

FIFO 往往是一种方式。如果您想要一个既可以读取又可以写入的 FIFO,那么您真正想要的可能是一对 FIFO(每个方向一个)或一个 UNIX 套接字。

于 2010-04-27T15:21:19.797 回答
3

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

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

于 2010-04-27T15:46:52.400 回答
0

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

由于死锁的可能性,通常不鼓励双向管道(prog1 正在等待来自 prog2 的数据,而后者正在等待来自 prog1 的数据,而后者正在等待来自 prog2 的数据......),但这也可能发生在任何变通方法中,并且可以使用诸如 SMTP(简单邮件传输协议)之类的常用协议发生,因为每一方都在对话中发挥作用。

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

于 2010-04-27T17:54:19.010 回答