我有一个Windows GUI应用程序,它使用第三方库将调试/错误信息打印到stdout / stderr。我找到了许多解决方案,可以将它们重定向到我的日志文件。但是,4个中只有1.5个按预期工作。我在WinXP SP3 32位上使用VS 2008 SP1。我没有包含错误处理,但没有调用返回错误。
// First one:
SetStdHandle(STD_OUTPUT_HANDLE, (HANDLE)_get_osfhandle(_fileno(log_file.get_FILE())));
SetStdHandle(STD_ERROR_HANDLE, (HANDLE)_get_osfhandle(_fileno(log_file.get_FILE())));
printf("%s", "1 Test printf to cout!\n");
fprintf(stderr, "%s", "1 Test printf to cerr!\n");
std::cout << "1 Test print to cout!\n";
std::cerr << "1 Test print to cerr!\n";
fflush(stdout);
fflush(stderr);
// Second one:
_dup2(_fileno(log_file.get_FILE()), _fileno(stdout));
_dup2(_fileno(log_file.get_FILE()), _fileno(stderr));
printf("%s", "2 Test printf to cout!\n");
fprintf(stderr, "%s", "2 Test printf to cerr!\n");
std::cout << "2 Test print to cout!\n";
std::cerr << "2 Test print to cerr!\n";
fflush(stdout);
fflush(stderr);
// Third one:
std::ofstream out_stream(log_file.get_FILE());
std::cout.rdbuf(out_stream.rdbuf());
std::cerr.rdbuf(out_stream.rdbuf());
printf("%s", "3 Test printf to cout!\n");
fprintf(stderr, "%s", "3 Test printf to cerr!\n");
std::cout << "3 Test print to cout!\n";
std::cerr << "3 Test print to cerr!\n";
fflush(stdout);
fflush(stderr);
// Fourth one:
*stdout = *log_file.get_FILE();
*stderr = *log_file.get_FILE();
printf("%s", "4 Test printf to cout!\n");
fprintf(stderr, "%s", "4 Test printf to cerr!\n");
std::cout << "4 Test print to cout!\n";
std::cerr << "4 Test print to cerr!\n";
fflush(stdout);
fflush(stderr);
在我测试它们之后(当然是单独的),我得到了这些结果:
3测试打印到cout!
3测试打印到cerr!
4测试printf到cout!
4测试打印到cout!
4测试printf到cerr!
4测试打印到cerr!
为什么只有最后一个解决方案才能完全运行?使用它安全吗?
更新。 XCode测试结果:
2测试printf到cout!
2测试打印到cout!
2测试printf到cerr!
2测试打印到cerr!
4测试printf到cout!
4测试打印到cout!
4测试printf到cerr!
4测试打印到cerr!
第一个显然是Windows,第三个是失败的,因为没有文件流构造函数接受FILE *参数。
答案 0 :(得分:0)
从最后:
FILE
pointer更改为stdout和stderr。显而易见的原因。 std :: cout和std :: cerr最终将输出发送到这些指针。