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

posts - 23,  comments - 20,  trackbacks - 0
前段時(shí)間自己寫了一個(gè)日志類  不過是MFC寫的   今天閑著沒事  就用SDK重寫了這個(gè)類  算是增加一點(diǎn)可移植性吧...
類的使用也很簡單  初始化的時(shí)候傳遞一個(gè)日志名稱 
然后在需要寫日志的地方 直接調(diào)用這個(gè)對象的WriteLog函數(shù)傳遞一個(gè)字符串進(jìn)去就行了
如果需要時(shí)間戳  則調(diào)用WriteLogWithTime函數(shù)  一樣的接口
支持設(shè)置日志大小  SetLogSize()   //KB計(jì)算
代碼很簡單  一百來行  不過用著還算挺方便的  下午就用這個(gè)日志類找到了一個(gè)以前工程中的SQL相關(guān)聯(lián)的BUG 呵呵 

.h文件
/*****************************************************
*文件名稱: Log_SDK.h
*功能說明: 使用SDK + STL重寫的一個(gè)日志類 增加可移植性
*創(chuàng)建時(shí)間: 09.10.31
*文件作者: zip
*****************************************************
/
#pragma once
#include 
<string>
using namespace std;

class LogSDK
{
public:
    LogSDK(
string strFileName);
    
~LogSDK(void);
    BOOL InitLogSDK();
    BOOL WriteLog(TCHAR
* pContent);
    BOOL WriteLogWithTime(TCHAR
* pContent);        //每次寫一行 且?guī)r(shí)間
    BOOL WriteLogAtFirstLine(TCHAR* pContent);    //將最近的日志寫在最前面    
    void SetLogSize(int iSize);

private:
    HANDLE m_hFile;
    
string m_strFileName;
    
string m_strFormat; 
    CRITICAL_SECTION m_cs;                
//臨界區(qū)
    BOOL m_bInit;                            //初始化標(biāo)志位
    int m_iSize;                                //文件大小    -- KB計(jì)算

    
string GetTimeStr();
};

.cpp文件
/***************************************************
*文件名稱: Log_SDK.cpp
*功能說明: LogSDK的實(shí)現(xiàn)文件
*創(chuàng)建時(shí)間: 09.10.31
*文件作者: zip
***************************************************
/
#include 
"StdAfx.h"
#include 
".\log_sdk.h"

LogSDK::LogSDK(
string strFileName)
{
    m_bInit 
= FALSE;
    m_strFileName 
= strFileName;
    m_iSize 
= 20;    //默認(rèn)20KB
    InitLogSDK();
}

LogSDK::
~LogSDK(void)
{
    CloseHandle(m_hFile);
}

BOOL LogSDK::InitLogSDK()
{    
    m_hFile 
= CreateFile(m_strFileName.c_str() , GENERIC_ALL ,
        FILE_SHARE_WRITE , NULL ,  OPEN_ALWAYS , FILE_ATTRIBUTE_NORMAL , NULL);
    
if (m_hFile == INVALID_HANDLE_VALUE)
    {
        DWORD dwErrorCode 
= GetLastError();
        TCHAR szErrMsg[
255];
        sprintf(szErrMsg , 
"打開文件失敗 , 錯(cuò)誤代碼:%d" , dwErrorCode);
        
//AfxMessageBox(szErrMsg);
        MessageBox(NULL , szErrMsg , _T("警告") ,IDOK);
        
return FALSE;
    }
    ::InitializeCriticalSection(
&m_cs);    //初始化臨界區(qū)
    m_bInit = TRUE;
    
return TRUE;
}

//普通的寫日志
BOOL LogSDK::WriteLog(TCHAR* pContent)
{
    ASSERT(m_bInit);
    DWORD dwFileLenHigh;
    DWORD dwFileLen 
= GetFileSize(m_hFile , &dwFileLenHigh);
    
if (dwFileLen > (DWORD)m_iSize * 1024)    //文件過大 清空文件
    {
        SetFilePointer(m_hFile , 
0 , NULL , FILE_BEGIN);    //移動(dòng)文件指針
        SetEndOfFile(m_hFile);//清空文件
    }
    
string strContent(pContent);
    strContent 
+= "\r\n";

    BOOL bRet 
= TRUE;
    ::EnterCriticalSection(
&m_cs);
    SetFilePointer(m_hFile , 
0 , NULL , FILE_END);    //移動(dòng)到文件末尾
    DWORD dwWriteLen;
    BOOL bSuccess 
= WriteFile(m_hFile , strContent.c_str() ,
        (DWORD)strContent.length() , 
&dwWriteLen , NULL);
    ASSERT(dwWriteLen 
== strContent.length());
    
if (!bSuccess)
    {
        DWORD dwErrorCode 
= GetLastError();
        TCHAR szErrMsg[
255];
        sprintf(szErrMsg , 
"寫入日志文件失敗 , 錯(cuò)誤代碼:%d" , dwErrorCode);        
        MessageBox(NULL , szErrMsg , _T(
"發(fā)生了嚴(yán)重的錯(cuò)誤") , IDOK);
        bRet 
= FALSE;    //此處不用返回  還要釋放臨界區(qū)
    }
    ::LeaveCriticalSection(
&m_cs);

    
return bRet;
}

//帶有時(shí)間戳的日志
BOOL LogSDK::WriteLogWithTime(TCHAR* pContent)
{
    ASSERT(m_bInit);
    DWORD dwFileLenHigh;
    DWORD dwFileLen 
= GetFileSize(m_hFile , &dwFileLenHigh);
    
if (dwFileLen > (DWORD)m_iSize * 1024)    //文件過大 清空文件
    {
        SetFilePointer(m_hFile , 
0 , NULL , FILE_BEGIN);    
        SetEndOfFile(m_hFile);
//清空文件
    }
    
//strcat(pContent , "\r\n");
    string strContent(pContent);
    strContent 
+= "\r\n";
    strContent.insert(
0 , "  ");
    strContent.insert(
0 , GetTimeStr());

    BOOL bRet 
= TRUE;
    ::EnterCriticalSection(
&m_cs);
    SetFilePointer(m_hFile , 
0 , NULL , FILE_END);    //移動(dòng)到文件末尾
    DWORD dwWriteLen;
    BOOL bSuccess 
= WriteFile(m_hFile , strContent.c_str() ,
        (DWORD)strContent.length() , 
&dwWriteLen , NULL);
    ASSERT(dwWriteLen == strContent.length());
    if (!bSuccess)
    {
        DWORD dwErrorCode 
= GetLastError();
        TCHAR szErrMsg[
255];
        sprintf(szErrMsg , 
"寫入日志文件失敗 , 錯(cuò)誤代碼:%d" , dwErrorCode);        
        MessageBox(NULL , szErrMsg , _T(
"發(fā)生了嚴(yán)重的錯(cuò)誤") , IDOK);
        bRet 
= FALSE;    //此處不用返回  還要釋放臨界區(qū)
    }
    ::LeaveCriticalSection(
&m_cs);

    
return bRet;
}

//返回格式化的時(shí)間字符串
string LogSDK::GetTimeStr()
{
    SYSTEMTIME sys;
    ::GetLocalTime(
&sys);    //獲取當(dāng)前系統(tǒng)時(shí)間
    TCHAR szTime[64];
    memset(szTime , 
0 , 64);
    sprintf(szTime , 
"%d-%02d-%02d %02d:%02d:%02d.%03d" , 
        sys.wYear , sys.wMonth , sys.wDay , sys.wHour , sys.wMinute , sys.wSecond , sys.wMilliseconds);
    
return string(szTime);
}

void LogSDK::SetLogSize(int iSize)
{
    m_iSize 
= iSize;
}

也可以算鍛煉一下API的操作吧...

posted on 2009-10-31 17:58 李佳 閱讀(1185) 評論(1)  編輯 收藏 引用 所屬分類: WIN32 應(yīng)用開發(fā)

FeedBack:
# re: 一個(gè)簡單的日志類 SDK + STL寫的[未登錄]
2009-12-02 14:36 | expter
日志類不用加鎖,看你的代碼,直接用singleton,對于一些日志可以看看boost,oege.cugi的寫法。。。

  回復(fù)  更多評論
  
<2025年10月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

常用鏈接

留言簿

隨筆分類

隨筆檔案

文章檔案

相冊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久久久一区二区三区| 欧美激情一区二区| 久久国产加勒比精品无码| 亚洲欧美春色| 欧美亚洲三级| 久久中文久久字幕| 亚洲国产成人porn| 欧美激情精品久久久久久久变态 | 亚洲国产一区二区三区a毛片| 国产一区二区三区成人欧美日韩在线观看 | 欧美国产日韩一区二区在线观看| 欧美不卡激情三级在线观看| 91久久精品国产91性色| 日韩午夜三级在线| 欧美一级视频精品观看| 美女国产一区| 国产精品一二一区| 亚洲精品欧美一区二区三区| 亚洲一区二区三区精品动漫| 久久婷婷人人澡人人喊人人爽 | 午夜精品成人在线| 美女福利精品视频| 欧美图区在线视频| 亚洲观看高清完整版在线观看| 一区二区欧美视频| 蜜乳av另类精品一区二区| 亚洲久久一区二区| 久久久99久久精品女同性| 欧美日韩国产二区| 在线高清一区| 欧美亚洲一区在线| 亚洲精品美女91| 久久久久久久精| 国产精品你懂的在线欣赏| 亚洲电影免费在线观看| 欧美在线啊v| 一区二区三区产品免费精品久久75 | 久久久综合精品| 国产精品theporn88| 国产偷久久久精品专区| 一区二区三区精品视频| 欧美ed2k| 久久精品成人| 国产女精品视频网站免费| 日韩一区二区精品葵司在线| 国产欧美日韩精品一区| 欧美激情1区2区3区| 国产亚洲美州欧州综合国| 亚洲色图制服丝袜| 欧美国产亚洲视频| 久久久国产精品一区二区中文 | 欧美午夜精品伦理| 亚洲欧洲偷拍精品| 欧美成人免费全部| 久久久久久久999| 伊甸园精品99久久久久久| 久久久久九九九| 午夜精品视频在线观看一区二区| 国产精品99免费看| 亚洲午夜精品久久久久久浪潮| 亚洲精品国产无天堂网2021| 欧美福利在线观看| 99v久久综合狠狠综合久久| 欧美激情二区三区| 欧美精品电影| 亚洲影院色无极综合| 在线一区免费观看| 国产精品人人做人人爽| 欧美夜福利tv在线| 午夜一区二区三区在线观看| 国产一区二区欧美日韩| 理论片一区二区在线| 久热综合在线亚洲精品| 亚洲精品乱码久久久久久日本蜜臀| 亚洲国产日韩欧美一区二区三区| 欧美精品久久久久久久久老牛影院| 亚洲人线精品午夜| 99视频一区二区| 国产色产综合色产在线视频| 久热这里只精品99re8久| 免费h精品视频在线播放| 日韩视频在线观看一区二区| 一区二区三区精品国产| 国产日韩亚洲欧美精品| 欧美国产视频在线| 欧美日韩久久精品| 性做久久久久久久久| 久久精品免费播放| 正在播放欧美视频| 久久久91精品国产| 亚洲系列中文字幕| 久久综合伊人| 欧美一级在线播放| 欧美国产视频在线| 久久久久国产精品厨房| 欧美屁股在线| 久久久天天操| 欧美日韩亚洲高清一区二区| 久久久久久夜| 欧美性猛交xxxx乱大交蜜桃 | 欧美日韩在线综合| 久久综合伊人77777| 欧美日韩一二区| 亚洲国语精品自产拍在线观看| 午夜一区不卡| 欧美电影免费网站| 亚洲欧美在线一区| 欧美成人一区二区在线| 久久国产精品电影| 欧美日韩三级| 欧美激情亚洲精品| 韩国三级在线一区| 亚洲影视中文字幕| 国产精品99久久久久久www| 久久久一本精品99久久精品66| 亚洲欧美在线另类| 欧美日韩在线视频一区二区| 欧美国产欧美综合| 亚洲电影视频在线| 久久成人国产| 久久av一区二区三区亚洲| 欧美午夜寂寞影院| 亚洲免费av片| 一区二区三区四区五区在线| 欧美国产综合一区二区| 欧美黄色一级视频| 亚洲国产精品视频一区| 午夜精品一区二区三区在线播放| 亚洲视频免费观看| 欧美日韩调教| 亚洲美洲欧洲综合国产一区| 9人人澡人人爽人人精品| 欧美aa在线视频| 欧美黄色日本| 亚洲精选一区| 欧美理论在线| 一区二区三区国产精品| 亚洲欧美日韩精品久久奇米色影视 | 久久九九精品99国产精品| 国产精品久线观看视频| 日韩视频在线观看| 一区二区国产精品| 欧美少妇一区二区| 亚洲午夜羞羞片| 欧美中文字幕在线| 激情欧美国产欧美| 久久亚洲精品一区二区| 欧美国产在线观看| 一区二区免费看| 国产精品男女猛烈高潮激情| 亚洲免费一级电影| 久久午夜羞羞影院免费观看| 在线精品视频一区二区三四| 免费观看在线综合色| 亚洲开发第一视频在线播放| 亚洲尤物在线| 国产亚洲精品久久久久久| 久久久国产精品一区| 亚洲激情社区| 午夜精品久久久久| 国产自产女人91一区在线观看| 久久青青草综合| 日韩午夜免费视频| 久久尤物视频| 亚洲小说春色综合另类电影| 国产亚洲免费的视频看| 欧美 日韩 国产一区二区在线视频 | 久久精品道一区二区三区| 久久色在线观看| 亚洲日本免费| 国产精品美女999| 久久www成人_看片免费不卡| 欧美激情一区二区三级高清视频| 亚洲午夜视频| 在线免费观看成人网| 欧美日韩一区二区在线观看| 欧美在线综合视频| 亚洲国产精品一区二区www| 午夜精品久久久久久久蜜桃app| 极品少妇一区二区三区| 欧美激情视频一区二区三区在线播放| 99国产精品久久久久老师 | 亚洲欧洲在线视频| 亚洲午夜av| 亚洲高清色综合| 国产精品www994| 欧美1区视频| 久久久综合网站| 欧美一区1区三区3区公司| 亚洲免费观看| 欧美激情一区二区久久久| 久久女同互慰一区二区三区| 亚洲一区二区动漫| 亚洲精品免费看| 在线精品一区二区| 国模叶桐国产精品一区| 国产九色精品成人porny| 欧美日韩中文字幕在线| 欧美国产亚洲另类动漫| 美国十次成人|