首页| 论坛| 消息

标题:怎么把所有调试信息输出到日志文件中
作者:shixingya
日期:2019-02-18 22:09
内容:

知道QDebug怎么输出到日志文件
想把第三方库std::cout, printf打印的调试信息全部输入到日志文件中,该怎么操作呢?


#1 [sharkoasis 02-19 17:28]
可以用dup吧
#2 [stlcours 02-19 19:21]
在QT/MFC中打开控制台输出printf的调试信息(AllocConsole申请,然后使用_open_osfhandle重定向)
// 在qt 中打开控制台窗口,首先include Window.h 头文件
#define SHOW_CONSOLE_WINDOW
#ifdef SHOW_CONSOLE_WINDOW
#include
#endif
// 在main函数中添加代码,运行即可查看结果
#ifdef SHOW_CONSOLE_WINDOW
AllocConsole();
freopen("CONOUT$", "w+t", stdout);
printf("hello world\n");
#endif

// 在MFC 中打开控制台
// 引用头文件io.h 和 fcntl.h
#include
#include
// 初始化控制台窗口
void InitConsoleWindow()
{
AllocConsole();
HANDLE handle = GetStdHandle(STD_OUTPUT_HANDLE);
int hCrt = _open_osfhandle((long)handle, _O_TEXT);
FILE * hf = _fdopen(hCrt, "w");
*stdout = *hf;
}
// 在MFC窗口的OnInitDialog方法中调用 InitConsoleWindow
...
InitConsoleWindow();
printf("hello world\n");
https://blog.csdn.net/lwwl12/article/details/79816739
#3 [XChinux 02-20 12:56]
qInstallMessageHandler

回复 发表
主题 版块