封装Log4cplus后不能记录行号的问题

本文探讨了在封装Log4cplus后遇到无法记录行号的困境,建议尊重原创并完整引用作者tingsking18的文章,以便于读者理解和寻求帮助。
摘要由CSDN通过智能技术生成

版权声明

请尊重原创作品。转载请保持文章完整性,并以超链接形式注明原始作者“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]-> ==========
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值