青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

glxhyt

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  15 隨筆 :: 0 文章 :: 4 評論 :: 0 Trackbacks
  1#ifndef _LOGING_
  2#define _LOGING_
  3#include <iostream>
  4#include <string>
  5#include <fstream>
  6#include <time.h>
  7#include <sys/time.h>
  8#include <cstdlib>
  9#include <sstream>
 10#include <cstdarg>
 11
 12using namespace std;
 13
 14typedef enum en_logleval
 15{
 16    fatal = 0,
 17    error,
 18    warning,
 19    debug
 20
 21}
logleval_en;
 22
 23typedef struct tag_LogManangeInfo
 24{
 25    int      logleval;
 26    int      logoutype;
 27    string   logfilepath;
 28
 29}
LogManagementInfo_st;
 30
 31string strFileName;
 32string strFileMainPath;
 33
 34struct timeval t_time;
 35unsigned int __NR_gettid;
 36enum en_logleval leval_t;
 37struct tm *ptm = NULL;
 38
 39LogManagementInfo_st  LogManagementInfo-1-1""};
 40
 41string GetFileMainPath();
 42
 43void LogPrint(int level, char* info,);
 44
 45void LogInit(struct timeval t);
 46
 47void OutPrint(int leval1,
 48              struct timeval t1, unsigned int id1,
 49              string fuction1, int  line1, string file1, char *info1);
 50
 51void LogReture(struct timeval t1, unsigned int id1,
 52              string fuction1, int  line1, string file1,
 53              char *info1);
 54
 55void LogCheckArg(bool bl, struct timeval t1, unsigned int id1,
 56              string fuction1, int  line1, string file1,
 57              char *info1);
 58
 59#define SWITCHLEVEL(level,out)            switch(level) \
 60                                            {    case 0 :\
 61                                                     out<<"Fatal   log: "; \
 62                                                    break;    \
 63                                                 case 1 :\
 64                                                     out<<"Error   log: ";\
 65                                                    break;\
 66                                                 case 2:\
 67                                                     out<<"warning log: ";\
 68                                                     break;\
 69                                                 case 3:\
 70                                                     out<<"debug   log: ";\
 71                                                     break;\
 72                                                 default:\
 73                                                     out<<"Info"<<"["<<level-4<<"]"<<" log: ";\
 74                                                    break;\
 75                                            }
\
 76
 77#define WRITELOG(out)   ptm = localtime(&t1.tv_sec);\
 78                        out<<ptm->tm_year+1900<<"-"<<ptm->tm_mon+1<<"-"<<ptm->tm_mday;\
 79                        out<<"-"<<ptm->tm_hour<<":"<<ptm->tm_min<<":"<<ptm->tm_sec<<".";\
 80                        out<<t1.tv_usec; \
 81                        file1 = strFileMainPath + file1.substr( file1.find('/') );\
 82                        out<<" "<<id1;\
 83                        out<<" "<<fuction1;\
 84                        out<<" "<<file1;\
 85                        out<<":"<<line1;\
 86                        out<<" "<<"Info: "<<info1<<endl;\
 87
 88#define  LOGINIT struct timeval t;\
 89         gettimeofday(&t, NULL); \
 90         LogInit(t)
 91
 92#define  LOGFATAL(info)  gettimeofday(&t_time, NULL); \
 93                         syscall(__NR_gettid);\
 94                         leval_t = fatal;\
 95                         OutPrint(leval_t, t, __NR_gettid, __FUNCTION__ ,__LINE__, __FILE__, info)
 96
 97#define  LOGERROR(info)  gettimeofday(&t_time, NULL); \
 98                         syscall(__NR_gettid);\
 99                         leval_t = error;\
100                         OutPrint(leval_t, t, __NR_gettid, __FUNCTION__, __LINE__, __FILE__, info)
101
102#define  LOGWARNING(info)  gettimeofday(&t_time, NULL); \
103                         syscall(__NR_gettid);\
104                         leval_t = warning;\
105                         OutPrint(leval_t, t, __NR_gettid, __FUNCTION__, __LINE__,  __FILE__, info)
106
107#define  LOGDEBUG(info)  gettimeofday(&t_time, NULL); \
108                         syscall(__NR_gettid);\
109                         leval_t = debug;\
110                         OutPrint(leval_t, t, __NR_gettid, __FUNCTION__, __LINE__, __FILE__, info)
111
112#define  LOGINFO(level, info)  gettimeofday(&t_time, NULL); \
113                         syscall(__NR_gettid);\
114                         OutPrint(level, t, __NR_gettid, __FUNCTION__, __LINE__,  __FILE__, info)
115
116
117#define  RETURN_NULL     gettimeofday(&t_time, NULL); \
118                         syscall(__NR_gettid);\
119                         LogReture( t_time, __NR_gettid, __FUNCTION__, __LINE__, __FILE__, "return 0");\
120                         LogManagementInfo.logleval = debug;\
121                         return 0;\
122
123#define  RETURN(val)     gettimeofday(&t_time, NULL); \
124                         syscall(__NR_gettid);\
125                         LogReture( t_time, __NR_gettid, __FUNCTION__, __LINE__, __FILE__, "return val");\
126                         LogManagementInfo.logleval = debug;\
127                         return(val);\
128
129#define  LOGCHECKARG(bl, info)     gettimeofday(&t_time, NULL); \
130                                   syscall(__NR_gettid);\
131                                   LogCheckArg(bl, t_time, __NR_gettid, __FUNCTION__, __LINE__, __FILE__, info)
132
133
134#endif
135
  1
  2//============================================================================
  3// Name        : loging.cpp
  4// Author      : 
  5// Version     :
  6// Copyright   : Your copyright notice
  7// Description : Hello World in C++, Ansi-style
  8//============================================================================
  9
 10#include "loging.h"
 11#include <cstdio>
 12#include <string>
 13using namespace std;
 14
 15string GetFileMainPath()
 16{
 17    char buffer[256];
 18    getcwd(buffer, 256);
 19    string strTemp = buffer;
 20    return strTemp;
 21}

 22
 23void LogInit(struct timeval t)
 24{
 25   ifstream out("/home/ganhm/logging/loging.conf");
 26   while(NULL != out)
 27   {
 28     string str;
 29     string begsubstr;
 30     string endsubstr;
 31     getline( out, str, '\n');
 32     unsigned int logbegpos = str.find_first_of('='0);
 33     unsigned int logendpos = str.find_first_of('\0', logbegpos);
 34
 35     begsubstr = str.substr(0, logbegpos);
 36     if(begsubstr == "loglevel")
 37     {
 38         endsubstr = str.substr(logbegpos + 1, logendpos - logbegpos);
 39         if(endsubstr == "fatal")
 40         {
 41             LogManagementInfo.logleval = fatal;
 42         }

 43         else if(endsubstr == "error")
 44         {
 45             LogManagementInfo.logleval = error;
 46         }

 47         else if(endsubstr == "warning")
 48         {
 49             LogManagementInfo.logleval = warning;
 50         }

 51         else if(endsubstr == "debug")
 52         {
 53             LogManagementInfo.logleval = debug;
 54         }

 55         else if((endsubstr.substr(0,4)) == "info")
 56         {
 57            cout<<"endlsubstr "<<endsubstr<<endl;
 58            string strInfoNum = endsubstr.substr(endsubstr.find('['+ 11);
 59            cout<<"strInfoNum "<<strInfoNum<<endl;
 60            int iInfoNum;
 61            stringstream stream;
 62            stream<<strInfoNum;
 63            stream>>iInfoNum;
 64            cout<<"iInfoNum "<<iInfoNum<<endl;
 65            LogManagementInfo.logleval = iInfoNum + 4;
 66            cout<<"LogManagementInfo.logleval "<<LogManagementInfo.logleval<<endl;
 67         }

 68     }

 69    else if(begsubstr == "logouttype")
 70     {
 71         endsubstr = str.substr(logbegpos + 1 , logendpos - logbegpos);
 72         stringstream stream;
 73         int ilogouttype;
 74         stream<<endsubstr;
 75         stream>>ilogouttype;
 76         cout<<"ilogouttype"<<ilogouttype<<endl;
 77           LogManagementInfo.logoutype = ilogouttype;
 78     }

 79    else if(begsubstr == "logfilepath")
 80     {
 81         endsubstr = str.substr(logbegpos +1 , logendpos - logbegpos);
 82         LogManagementInfo.logfilepath = endsubstr;
 83     }

 84
 85   }

 86
 87   if(LogManagementInfo.logleval  == -1)
 88   {
 89       LogManagementInfo.logleval = 2;
 90   }

 91   cout<<"leval"<<LogManagementInfo.logleval<<endl;
 92   if(LogManagementInfo.logoutype == -1)
 93   {
 94       LogManagementInfo.logoutype = 0;
 95   }

 96
 97   cout<<"type"<<LogManagementInfo.logoutype<<endl;
 98   strFileMainPath = GetFileMainPath();
 99   cout<<"FeilManiPath"<<strFileMainPath<<endl;
100
101   string strFileNameAfer = strFileMainPath.substr(strFileMainPath.rfind('/'+ 1+ ".log";
102   if(LogManagementInfo.logfilepath == "")
103   {
104       strFileName =  strFileNameAfer;
105   }

106   else
107   {
108       string strManagementINfoTemp = (LogManagementInfo.logfilepath).substr(0 ,(LogManagementInfo.logfilepath).rfind('/'+ 1);
109       strFileName = strManagementINfoTemp + strFileNameAfer;
110   }

111   cout<<"GETFILENAME   "<<strFileName<<endl;
112}

113
114void OutPrint(int leval1,
115              struct timeval t1, unsigned int id1,
116              string fuction1, int line1, string file1, char *info1)
117{
118  if(LogManagementInfo.logleval >= leval1)
119   {
120       if(LogManagementInfo.logoutype == 0)
121       {
122                    SWITCHLEVEL(leval1, cout);
123                    WRITELOG(cout);
124        }

125        else if(LogManagementInfo.logoutype == 1)
126        {
127                   ofstream fout(strFileName.c_str(), ios::ate | ios::app );
128                  SWITCHLEVEL(leval1, fout);
129                  WRITELOG(fout);
130        }

131  }

132}

133
134void LogReture(struct timeval t1, unsigned int id1,
135              string fuction1, int  line1, string file1,
136              char *info1)
137{
138           if(LogManagementInfo.logoutype == 0)
139           {
140                     cout<<"RETURN  log: ";
141                     WRITELOG(cout);
142            }

143        else if(LogManagementInfo.logoutype == 1)
144            {
145                   ofstream fout((strFileName.c_str()), ios::ate | ios::app );
146                   if(fout == NULL)
147                   {
148                       cout<<"fout = NULL"<<endl;
149                   }

150                   fout<<"RETURN  log: ";
151                   WRITELOG(fout);
152            }

153}

154
155void LogCheckArg(bool bl, struct timeval t1, unsigned int id1,
156                string fuction1, int  line1, string file1,
157                char *info1)
158{
159               if(LogManagementInfo.logoutype == 0)
160               {
161                            cout<<"Check   log: ";
162                            WRITELOG(cout);
163                            if(bl == true)
164                            {
165                                 LogManagementInfo.logleval = error;
166                              cout<<" 正確"<<endl;
167                            }

168                            else
169                            {
170                                   LogManagementInfo.logleval = debug;
171                                cout<<" 錯誤"<<endl;
172                            }

173               }

174                else if (LogManagementInfo.logoutype == 1)
175                     {
176                             ofstream fout((strFileName.c_str()), ios::ate | ios::app );
177                                  cout<<"Check   log: ";
178                                  WRITELOG(fout);
179                                if(bl == true)
180                                {
181                                        LogManagementInfo.logleval = error;
182                                    fout<<" 正確"<<endl;
183                                }

184                                else
185                                {
186                                        LogManagementInfo.logleval = debug;
187                                    fout<<" 錯誤"<<endl;
188                                }

189                    }

190}

191void LogPrint(int level, char* info,)
192{
193       if(LogManagementInfo.logleval >= level)
194       {
195           if(LogManagementInfo.logoutype == 0)
196           {
197                    va_list argptr;
198                    va_start(argptr, info);
199                    char buffer[256];
200                    vsprintf( buffer,info,argptr);
201                    va_end(argptr);
202                    cout<<"附加信息 log: ";
203                    cout<<" "<<"Info "<<buffer<<endl;
204           }

205           else if(LogManagementInfo.logoutype == 1)
206           {
207                 ofstream fout((strFileName.c_str()), ios::ate | ios::app );
208                    va_list argptr;
209                    va_start(argptr, info);
210                    char buffer[256];
211                    vsprintf( buffer,info,argptr);
212                    va_end(argptr);
213                    fout<<"Info"<<endl;
214                    fout<<"附加信息 log: ";
215                    fout<<" "<<"Info "<<buffer<<endl;
216           }

217       }

218}

219
220
221
222
223
 1#include  "loging.h"
 2#include  <iostream>
 3
 4using namespace std;
 5int fun1();
 6int fun()
 7{
 8    RETURN_NULL;
 9}

10int fun1()
11{
12    RETURN(2);
13}

14int main()
15{
16    char *pFatalInfo = "Fatal Log";
17    char *pErrorInfo = "Error Log";
18    char *pWarringInfo = "Waring Log";
19    char *pDebugInfo = "Debug Log";
20    char *pInfo1 = "info1";
21    char *pInfo2 = "info2";
22    char *pInfo3 = "info3";
23    char *= "bool bool";
24    LOGINIT;
25
26
27
28//    LOGFATAL(pFatalInfo);
29//    LOGERROR(pErrorInfo);
30//    LOGWARNING(pWarringInfo);
31//    LOGDEBUG(pDebugInfo);
32//    LOGINFO(0, pInfo1);
33    LOGINFO(1, pInfo1);
34    LOGINFO(2, pInfo1);
35    LOGINFO(3, pInfo1);
36    LOGINFO(4, pInfo1);
37    LOGINFO(5, pInfo1);
38    LOGINFO(6, pInfo1);
39    LOGINFO(7, pInfo1);
40    LOGINFO(8, pInfo1);
41
42
43    LogPrint(4,"%d %f %c"11.2'c');
44
45    unsigned int __NR_gettid;
46    syscall(__NR_gettid);
47    cout<<"__NR_gettid"<<__NR_gettid<<endl;
48    fun();
49    fun1();
50
51
52    LOGCHECKARG(false, b);
53      return 0;
54}

55
posted on 2010-08-19 19:18 郭龍 閱讀(1686) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲黄色在线观看| 久久阴道视频| 欧美区亚洲区| 一区二区视频欧美| 欧美一区二区啪啪| 亚洲精品三级| 欧美成人精品一区二区| 一区视频在线看| 久久久久久一区二区三区| 亚洲一二区在线| 欧美精品二区| 亚洲精品美女在线| 欧美mv日韩mv国产网站app| 午夜久久久久久久久久一区二区| 欧美金8天国| 亚洲精品一区二区在线| 免费亚洲一区| 欧美一区二区三区日韩视频| 国产精品久久国产愉拍| 亚洲午夜久久久| 日韩视频在线观看免费| 欧美人成免费网站| 亚洲精品乱码久久久久久| 欧美国产免费| 久久久人成影片一区二区三区观看| 国产欧美精品在线| 性做久久久久久| 亚洲欧美制服另类日韩| 国产精品日韩在线| 香蕉久久a毛片| 亚洲一区视频| 国产九区一区在线| 欧美在线视频在线播放完整版免费观看| 一本色道久久综合狠狠躁篇怎么玩 | 国产一区二区观看| 久久av二区| 午夜欧美精品| 国产一区二区三区精品久久久| 欧美一区在线直播| 欧美一区二区三区视频在线| 国产在线观看一区| 久久婷婷国产麻豆91天堂| 久久激情视频久久| 在线观看亚洲一区| 亚洲电影免费观看高清完整版在线观看| 蜜臀av一级做a爰片久久| 亚洲激情小视频| 亚洲美女精品一区| 国产精品国产三级国产专播品爱网| 亚洲一区观看| 亚洲欧美日韩中文播放| 国内精品久久久久影院色| 久久午夜精品| 另类尿喷潮videofree| 亚洲精品一区二区三区福利| 日韩亚洲成人av在线| 国产精品美女久久久久av超清 | 久久久综合免费视频| 亚洲国产精品电影| 亚洲三级影院| 国产精品久久久久久影视| 久久aⅴ国产紧身牛仔裤| 久久久久久久久久久久久女国产乱 | 久久综合综合久久综合| 麻豆免费精品视频| 亚洲午夜视频在线观看| 性久久久久久久| 亚洲国产乱码最新视频| 亚洲精品小视频在线观看| 国产精品一区二区视频| 乱人伦精品视频在线观看| 欧美激情精品久久久久| 亚洲欧美久久久久一区二区三区| 欧美在线亚洲| 亚洲美洲欧洲综合国产一区| 亚洲自拍偷拍麻豆| 亚洲国产黄色片| av成人天堂| 韩国v欧美v日本v亚洲v| 91久久夜色精品国产九色| 国产精品嫩草99av在线| 免费日韩av| 国产精品久久久久久五月尺| 免费亚洲婷婷| 国产精品女人网站| 欧美国产第一页| 国产精品日产欧美久久久久| 免费中文日韩| 国产精品一区二区你懂的| 欧美黄色一区| 国产女主播一区| 亚洲人成人一区二区三区| 国产欧美日韩一级| 亚洲国产经典视频| 国产手机视频精品| 亚洲乱码国产乱码精品精天堂 | 亚洲欧洲精品一区二区三区| 正在播放亚洲| 亚洲激情网站免费观看| 午夜在线观看免费一区| 夜夜嗨av一区二区三区网页| 久久av在线看| 香蕉av福利精品导航| 欧美精品18videos性欧美| 久久亚洲精品视频| 国产精品卡一卡二卡三| 亚洲日本欧美| 伊人久久综合| 欧美一级日韩一级| 亚洲女性喷水在线观看一区| 亚洲区免费影片| 亚洲午夜久久久久久久久电影院 | 久久久99免费视频| 欧美日韩一区免费| 亚洲成人在线视频播放| 国产一区视频网站| 亚洲天堂成人| 日韩视频一区二区三区在线播放免费观看 | 亚洲欧美日韩国产中文在线| 99亚洲一区二区| 久久婷婷国产麻豆91天堂| 欧美在线免费视屏| 欧美视频一区二区三区…| 欧美顶级大胆免费视频| 含羞草久久爱69一区| 午夜日韩在线观看| 午夜精品一区二区三区四区| 欧美激情第3页| 欧美成人免费一级人片100| 国产香蕉久久精品综合网| 国产精品99久久久久久久女警 | 亚洲美女性视频| 欧美1级日本1级| 美女亚洲精品| 在线成人免费视频| 亚洲性视频网址| 久久久亚洲午夜电影| 久久久久久久综合日本| 久久久久久电影| 久久精品一二三| 国产伦精品一区二区三区| 亚洲视频在线播放| 亚洲欧美成人网| 欧美性开放视频| 夜夜夜久久久| 亚洲午夜精品国产| 国产精品s色| 亚洲午夜精品视频| 亚洲欧美综合网| 国产精品人人做人人爽人人添 | 国产农村妇女精品一区二区| 宅男噜噜噜66国产日韩在线观看| 亚洲一级一区| 国产精品乱码一区二三区小蝌蚪 | 亚洲一区二区三区高清| 欧美日韩免费视频| 夜夜嗨av一区二区三区四区| 亚洲一区观看| 国产欧美韩国高清| 久久成人综合网| 欧美成人精品高清在线播放| 亚洲国语精品自产拍在线观看| 久久综合电影| 亚洲欧洲日本一区二区三区| 日韩一二在线观看| 欧美揉bbbbb揉bbbbb| 亚洲一区二区三区欧美| 久久精品中文字幕免费mv| 狠狠色狠狠色综合日日tαg | 欧美在线3区| 国产一区二区在线观看免费| 久久精品视频免费播放| 欧美激情小视频| 一本久久a久久精品亚洲| 欧美先锋影音| 欧美在线视频免费观看| 欧美成人网在线| 中国日韩欧美久久久久久久久| 国产精品久久久久7777婷婷| 午夜精品婷婷| 欧美成人dvd在线视频| 99re8这里有精品热视频免费 | 免费成人av在线| 亚洲精品四区| 欧美在线一级va免费观看| 极品尤物久久久av免费看| 欧美岛国在线观看| 一区二区日韩精品| 久久另类ts人妖一区二区| 亚洲精品乱码久久久久久日本蜜臀 | 欧美成年人在线观看| 日韩一级黄色大片| 久久精品一本久久99精品| 亚洲激情视频在线播放| 欧美性猛交xxxx乱大交蜜桃| 久久激情视频久久| 日韩午夜av电影| 久久久久久穴| 一区二区精品在线| 国产亚洲毛片在线|