版权声明
请尊重原创作品。转载请保持文章完整性,并以超链接形式注明原始作者“tingsking18”和主站点地址,方便其他朋友提问和指正。
封装Log4cplus后不能记录行号的问题
在使用Log4cplus的时候,在配置文件中配置了%l,就是记录日志信息所在的文件和行号。我们可以直接LOG4CPLUS_ERROR(logger,LogMsg);来进行日志记录了。这样日志信息里面就会有我们日志信息所在文件和行号。
但是有的时候我们可能需要对log4cplus进行封装,封装后的代码可能会像下面的样子:
void _LogError(const char* fmt, ... )
{
char LogMsg[4096];
int strlen;
memset(LogMsg,0x00,sizeof(LogMsg));
va_list ap;
va_start(ap, fmt);
strlen = vsprintf(LogMsg, fmt, ap);
va_end(ap);
LOG4CPLUS_ERROR(logger,LogMsg);
return ;
}
但是这样的话,日志信息记录的文件名和行号就成了_LogError所在的文件和LOG4CPLUS_ERROR(logger,LogMsg);行的行号。这样就达不到我们想要的目的了。
2010-01-06 00:52:30 [test.cpp:47]-> ==============================================================
2010-01-06 00:52:30 [test.cpp:47]-> XXXXX日志
2010-01-06 00:52:30 [test.cpp:47]-> ==============================================================
2010-01-06 00:52:30 [test.cpp:47]-> 程序开始启动
想要记录到真正日志信息所在的文件和行,当然有办法:
我们可以定义两个全局变量:
char *filename;
int line;
然后定义一个宏:
#define LogError filename=__FILE__,line=__LINE__,_LogError
再把_LogError函数中的LOG4CPLUS_ERROR(logger,LogMsg);改成logger.log(ERROR_LOG_LEVEL,LogMsg,filename,line);
这样就可以了。
2010-01-06 00:52:43 [test.cpp:60]-> ==============================================================
2010-01-06 00:52:43 [test.cpp:61]-> XXXXX日志
2010-01-06 00:52:43 [test.cpp:62]-> ==============================================================
2010-01-06 00:52:43 [test.cpp:63]-> 程序开始启动
但是上述这种情况只适用于单线程。
如果要使用于多线程的环境中可以将filename和line实现为函数,就像errno在多线程的情况下的实现那样,其中要使用thread specific数据。
本文详细介绍了在使用Log4cplus进行日志记录时,如何在封装代码后保持日志信息正确记录到原始文件和行号的方法。通过定义全局变量和宏,实现了多线程环境下日志信息的准确跟踪。
1480

被折叠的 条评论
为什么被折叠?



