实现一个接受可变参数log函数

王朝other·作者佚名  2006-01-08
宽屏版  字体: |||超大  

实现一个接受可变参数log函数

小软件中总要写个log函数,log函数的写法有很多种,实现一个可以接受可变参数log函数看起来好象才不象一个农民伯伯程序员写的代码。所以下面,我写了一个简单的:

void coutLog (const char *format, ...)

{

static std::ofstream of("./xoe_syslog.log");

if (of)

{

time_t ltime;

time(&ltime);

char t1[24];

strftime(t1, 24, "%Y-%m-%d %H:%M:%S\0 ", localtime(&ltime));

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,里面人家做得多好啊(主要是自己人要说的,:))。

你要是觉得我中间能省就省,能诓就诓,保留了很多口水的话,也不是我不愿意多打些字,骗点注意力啊或显得学问高点啊,而是我要先抓紧把我的意思说完,才想去补充,可这个时候,我也没激情了,你也不愿意听了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有