gpt4 book ai didi

c++ - 如何在 C++ 中重定向断言输出?

转载 作者:行者123 更新时间:2023-11-28 03:33:35 25 4
gpt4 key购买 nike

当参数为 false 时,是否可以将 assert 输出重定向到文件?我知道它的默认行为是向 stderr 写入一条消息,但以下内容并没有像我预期的那样工作:

#include <iostream>
#include <assert>
#include <fstream>
using namespace std;
//---------------------------------------------------------------------------
int main(int argc, char* argv[])
{
ofstream ofs;
ofs.open("test.txt", ios_base::out);
ofs << "A";
cerr << "B";
cerr.rdbuf(ofs.rdbuf());
cerr << "C";
assert(1 == 2);
return 0;
}
//---------------------------------------------------------------------------

test.txt 中的结果:

AC

并在标准输出中产生结果:

B
Assertion failed: 1 == 2, file C:\xxx\Unit1.cpp, line 14
Abnormal program termination

不过,我原以为在 stdout 中打印的最后两行是在 test.txt 文件中。我也尝试过使用,而不是...

cerr.rdbuf(ofs.rdbuf());

以下内容:

freopen("test.txt", "a", stderr);

但效果不是很好。

我还看到一些帖子(如 C: how to redirect stderr from System-command to stdout or file?)建议使用 dup2 重定向流,例如在 unistd.h 中定义的 stderr。但我在 Windows 上使用 C++Builder,它似乎不可用。

最佳答案

您可以将所有输出重定向到 stderr,或将任何其他标准文件句柄重定向到程序开始时的文件。

   freopen( "error.log","w",stderr);

在这里阅读:

http://support.microsoft.com/kb/58667

@edit:如果输出到标准输出,那么你需要做:

   freopen( "error.log","w",stdout );

如果你想附加而不是覆盖 error.log:

   freopen( "error.log","aw",stdout );

关于c++ - 如何在 C++ 中重定向断言输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11850867/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com