实现一个接受可变参数log函数
小软件中总要写个log函数,log函数的写法有很多种,实现一个可以接受可变参数log函数看起来好象才不象一个农民伯伯程序员写的代码。所以下面,我写了一个简单的:
void coutLog (const char *format, ...)
{
static std::ofstream of("./xoe_syslog.log");
if (of)
{
time_t ltime;
time(<ime);
char t1[24];
strftime(t1, 24, "%Y-%m-%d %H:%M:%S\0 ", localtime(<ime));
of << t1;
va_list argList;
va_start(argList, format);
for (const char* lpsz = format; *lpsz != '\0'; ++lpsz)
{
if (*lpsz != '%')
{
of << *lpsz;
continue;
}
else
++lpsz;
switch (*lpsz)
{
case 'c':
case 'C':
of << va_arg(argList, int);
break;
case 's':
case 'S':
{
const char* pstrNextArg = va_arg(argList, const char *);
if (pstrNextArg != NULL)
of << pstrNextArg;
}
break;
case 'd':
case 'l':
of << va_arg(argList, int);
break;
case 'f':
of << va_arg(argList, double);
case 'p':
of << va_arg(argList, void*);
default:
break;
}
}
va_end(argList);
of << std::endl;
of.flush();
}
}
要编译通过,请包含头文件
#include <time.h>
#include <fstream>
#include <stdarg.h>
该代码在windows和linux上面都可以编译后执行。这里是把log写入文件中,你也可以变通一下,例如,可以先导入到一个istringstream或一个字串如std::string中,(记得如果log信息比较多的话,可以先reserve一下,免得重复申请内存,造成效律有点不高),然后再做处理:或输出或备案以后细读。
同样的,对其进行一下包装,可以做成一个日志功能模块。同源的大师级包装,请你看看ACE,里面人家做得多好啊(主要是自己人要说的,:))。
你要是觉得我中间能省就省,能诓就诓,保留了很多口水的话,也不是我不愿意多打些字,骗点注意力啊或显得学问高点啊,而是我要先抓紧把我的意思说完,才想去补充,可这个时候,我也没激情了,你也不愿意听了。
本文地址:http://com.8s8s.com/it/it28984.htm