我有两个进程,一个服务器和一个客户端,它们应该通过管道(C++、Linux)进行通信。O_RDONLY
服务器使用标志打开管道,客户端使用O_WRONLY
. 但是,服务器在open
函数处阻塞,而客户端似乎运行成功(open
函数返回成功,函数也是如此write
)。
我已经读过,如果O_NONBLOCK
设置了标志,读取功能将继续,但如果没有连接客户端,我不希望它继续 - 在连接客户端之前阻塞是可以的,但在我的情况下它仍然被阻塞客户端完成运行后...
你能告诉我我做错了什么......?
这是代码:
// Server side
int pipe;
int status, nr_read = 0;
status = mkfifo(FIFO_NAME, 0666);
if (status < 0)
{
// If the file already exists, delete it
unlink(FIFO_NAME);
// Try again
status = mkfifo(FIFO_NAME, 0666);
if(status < 0)
{
printf("mkfifo error: %d\n", status);
return status;
}
}
pipe = open(FIFO_NAME, O_RDONLY);
printf("Never gets here...\n");
[...]
nr_read = read(pipe, my_char_array, CHAR_ARRAY_SIZE);
[...]
close(pipe);
unlink(FIFO_NAME);
它永远不会到达“printf”行......
// Client side:
int pipe, nr_sent = 0;
int status = 0;
pipe = open(FIFO_NAME, O_WRONLY);
if (pipe < 0)
{
printf("open fifo error: %d\n", status);
return pipe;
}
[...]
nr_sent = write(pipe, my_char_array, CHAR_ARRAY_LENGTH);
[...]
close(pipe);
编辑
我没有提到这条线
#define FIFO_NAME "MYFIFO"
...这就是问题所在:正如乔迪·哈金斯所说,路径是相对路径,进程从不同文件夹启动,他们试图打开不同的文件。