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

版权声明

请尊重原创作品。转载请保持文章完整性,并以超链接形式注明原始作者“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数据。
阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在C#中使用log4net记录日志并包含行号信息,您需要进行以下配置: 首先,确保已在项目中安装了log4net包。您可以使用NuGet包管理器来安装它。 接下来,在您的应用程序中,创建一个log4net配置文件(通常以.xml或.config为扩展名)。在配置文件中,您需要添加一个<appender>元素来指定日志输出的目标(例如文件),并将ConversionPattern属性设置为包含%line的格式。这将在日志消息中包含行号信息。 以下是一个示例log4net配置文件的部分内容: ```xml <log4net> <appender name="FileAppender" type="log4net.Appender.FileAppender"> <file value="log.txt" /> <appendToFile value="true" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger - %message%newline%line" /> </layout> </appender> <root> <level value="DEBUG" /> <appender-ref ref="FileAppender" /> </root> </log4net> ``` 在您的应用程序的入口点(例如Main方法)中,添加以下代码初始化log4net: ```csharp using log4net; class Program { private static readonly ILog log = LogManager.GetLogger(typeof(Program)); static void Main(string[] args) { log4net.Config.XmlConfigurator.Configure(); // ... log.Debug("Debug message"); log.Info("Info message"); log.Error("Error message"); // ... } } ``` 这样,当您记录日志时,将包含行号信息。例如,如果您在代码的某一行上写入log.Debug("Debug message"),日志消息将显示为: ```txt 2021-01-01 12:34:56 [Main] DEBUG Program - Debug message ``` 请注意,行号信息将基于日志记录语句的位置自动添加,并不需要手动指定。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值