FIFO流水线服务器仅接收一定数量

时间:2016-06-02 17:43:51

标签: c client-server pipeline mkfifo

所以我正在尝试使用mkfifo()在C中实现基本的FIFO管道。 到目前为止,这是我的代码类:

main.c中:

int main(int argc, char *argv[]) {
char *path = "/tmp/fifo";
pid_t pid;

setlinebuf(stdout);
unlink(path);
mkfifo(path, 0600);

pid = fork();
if (pid == 0) {
    client(path);
} else {
    server(path);
}

return(0);
}

client.c:

void client(char *path) {

char *input;
input = (char *)malloc(200 * sizeof(char));

read(STDIN_FILENO, input, 200);

struct Message message;
message = protocol(input); //protocol simply takes an input string and formats it
char number = message.server;
char* string;
string = message.string;

int fd;

fd = open(path, O_WRONLY);
write(fd, string, sizeof(string));
printf("Client send: %s\n", string);
close(fd);


return;
}

server.c:

void server(char *path) {
int fd;
char *input;
input = (char *)malloc(200 * sizeof(char));

fd = open(path, O_RDONLY);
read(fd, input, sizeof(input));
printf("Server receive: %s\n", input);
close(fd);

return;
}

现在管道正在运行,但由于某种原因,服务器只接收部分消息。例如,如果我们从协议中获得以下字符串:“HELLO WORLD”我们得到以下输出:

Server receive: HELLO WO
Client send: HELLO WORLD

服务器应该收到整条消息,但事实并非如此。我究竟做错了什么?谢谢你的帮助!

1 个答案:

答案 0 :(得分:1)

我注意到您已经对openread以及write的返回值进行了必要的检查。如果你有,你可能已经注意到这一行中的错误

write(fd, string, sizeof(string));

因为string是指针,所以发送8个字节(指针的大小)。您应该使用strlen(string)+1,具体取决于是否需要发送终结符。

write(fd, string, strlen(string));

你在最近的不明智编辑中重复了这个错误:

read(fd, input, sizeof(input));

您最好坚持使用原始#define并将其用于缓冲区分配和读取请求大小。