所以我正在尝试使用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
服务器应该收到整条消息,但事实并非如此。我究竟做错了什么?谢谢你的帮助!
答案 0 :(得分:1)
我注意到您已经对open
和read
以及write
的返回值进行了必要的检查。如果你有,你可能已经注意到这一行中的错误
write(fd, string, sizeof(string));
因为string
是指针,所以发送8个字节(指针的大小)。您应该使用strlen(string)
或+1
,具体取决于是否需要发送终结符。
write(fd, string, strlen(string));
你在最近的不明智编辑中重复了这个错误:
read(fd, input, sizeof(input));
您最好坚持使用原始#define
并将其用于缓冲区分配和读取请求大小。