今天用MFC创建一个对话框程序并使用Easylogging++做日志输出,当程序中用TRACE打印信息时候,编译时候会报“error C3861: “TRACE”: 找不到标识符”,TRACE是MFC的宏,怎么可能出现这样的错误?经过反复注释代码发现是包含Easylogging++后才会出现这个错误,那么Easylogging做了什么?直接去看它的源码发现有这么写的
// Undef levels to support LOG(LEVEL)
#undef INFO
#undef WARNING
#undef DEBUG
#undef ERROR
#undef FATAL
#undef TRACE
#undef VERBOSE
看,它为了支持LOG级别,把这么多宏全部取消定义了。我们就剩下两条路了,要么改它的源码,要么不要用TRACE。
在afx.h中TRACE是这么定义的
// extern ATL::CTrace TRACE;
#define TRACE ATLTRACE
所以最简单就是不用TRACE,改用ATLTRACE。
当然也可以自己写个XXTRACE:
#ifdef _DEBUG
#ifndef XXTRACE
#define XXTRACE XX_Trace
#endif
void XX_Trace(LPCTSTR pstrFormat, ...)
{
#ifdef _DEBUG
TCHAR szBuffer[300] = { 0 };
va_list args;
va_start(args, pstrFormat);
::wvnsprintf(szBuffer, lengthof(szBuffer) - 2, pstrFormat, args);
_tcscat(szBuffer, _T("\n"));
va_end(args);
::OutputDebugString(szBuffer);
#endif
}