这是我用dup2测试的结果
更微妙的一点是在正确的时间记住fflush :)否则,你会得到非常令人惊讶的结果.
此外,更喜欢fileno而不是硬编码1(stdout)2(stderr).
重定向stdin是留给读者的练习
#include
#include
#include
#include
int main(int argc,const char *argv[])
{
int out = open("cout.log",O_RDWR|O_CREAT|O_APPEND,0600);
if (-1 == out) { perror("opening cout.log"); return 255; }
int err = open("cerr.log",0600);
if (-1 == err) { perror("opening cerr.log"); return 255; }
int save_out = dup(fileno(stdout));
int save_err = dup(fileno(stderr));
if (-1 == dup2(out,fileno(stdout))) { perror("cannot redirect stdout"); return 255; }
if (-1 == dup2(err,fileno(stderr))) { perror("cannot redirect stderr"); return 255; }
puts("doing an ls or something now");
fflush(stdout); close(out);
fflush(stderr); close(err);
dup2(save_out,fileno(stdout));
dup2(save_err,fileno(stderr));
close(save_out);
close(save_err);
puts("back to normal output");
return 0;
}@H_403_6@