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

类别:编程语言 点击:0 评论:0 推荐:

实现一个接受可变参数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,里面人家做得多好啊(主要是自己人要说的,:))。

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

本文地址:http://com.8s8s.com/it/it28984.htm