所以我有一个远程 shell 程序。当输出不是那么大时它工作得很好,但是当我从命令中获取大输出时它会挂起。
这是一段代码。我可以确认 args 按预期工作。例如,如果 args[0] = "ps"且 args=["ps", "-ael", NULL]。父进程将陷入 wait() 状态。 child 卡在 execvp() 上。但是,如果 args 只是 ["ps", "-a", NULL],则输出较少,它不会卡在 wait() 上。
我应该注意到这是在 Mac 上的操作。在 Linux 系统上崩溃并显示 free(): invalid next size (normal)。
...
if (fork() == 0) {
printf("fork %s\n", " ");
close(STDOUT_FILENO);
close(fds[0]);
dup2(fds[1], STDOUT_FILENO);
dup2(fds[0], STDIN_FILENO);
dup2(errorPipe[1], STDERR_FILENO);
close(fds[1]);
fflush(stdout);
if(0 < execvp(args[0], args)) {
perror("execvp failed");
printf("Command Failed! \n");
}
}
printf("%s\n", "waiting");
wait(0);
printf("%s\n", "done waiting");
char errorMessage[3000];
read(fds[0], msg, command->messageSize);
printf("msg %s\n", msg);
....
最佳答案
子进程正在等待您读取一些数据,然后再写入更多数据。内核不会为您记住所有数据,只会记住有限的数据。
您没有读取任何数据,因为您正在等待它完成。但在您读取数据之前它不会完成。
free(): invalid next size (normal)
是一个完全不同的问题 - 这意味着您正在覆盖一些不应该覆盖的内存。
关于c - Execvp 输出太大时挂起?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53621489/