我有以下代码:
pid_t pid = fork();
if (pid == -1)
{
// ...
}
else if (pid == 0)
{
stdin = someopenfile;
stdout = someotherfile;
stderr = somethirdopenfile;
execvp(args[0], args);
// handle error ...
}
else
{
// ...
}
问题是,execvp()
调用的输入/输出仍然是控制台,而不是文件。很明显我做错了什么,正确的方法是什么呢?
发布于 2013-01-27 09:20:06
正确的方法是将文件描述符STDIN_FILENO
、STDOUT_FILENO
和STDERR_FILENO
替换为使用dup2()
打开的文件。然后,您还应该关闭子进程中的原始文件:
else if (pid == 0)
{
dup2(fileno(someopenfile), STDIN_FILENO);
dup2(fileno(someotherfile), STDOUT_FILENO);
dup2(fileno(somethirdopenfile), STDERR_FILENO);
fclose(someopenfile);
fclose(someotheropenfile);
fclose(somethirdopenfile);
execvp(args[0], args);
// handle error ...
}
发布于 2013-01-27 09:15:13
看一看freopen
函数。
我不得不用stdout
做一些类似的事情,并编写了两个函数来为我做这项工作:
static int fd;
static fpos_t pos;
void switchStdout(const char *newStream)
{
fflush(stdout);
fgetpos(stdout, &pos);
fd = dup(fileno(stdout));
freopen(newStream, "w", stdout);
}
void revertStdout()
{
fflush(stdout);
dup2(fd, fileno(stdout));
close(fd);
clearerr(stdout);
fsetpos(stdout, &pos);
}
发布于 2017-03-10 21:21:20
当stdin、stdout、stderr为终端时,您可以使用它-
//change stdin,stdout,stderr
freopen("new_stdin","r",stdin);
freopen("new_stdout","r",stdout);
freopen("new_stderr","r",stderr);
//----do something;
//reset stdin,stdout,stderr
freopen("/dev/tty","r",stdin);
freopen("/dev/tty","r",stdout);
freopen("/dev/tty","r",stderr);
https://stackoverflow.com/questions/14543443
复制相似问题