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

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

.h文件
/*****************************************************
*文件名稱: Log_SDK.h
*功能說明: 使用SDK + STL重寫的一個日志類 增加可移植性
*創建時間: 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);        //每次寫一行 且帶時間
    BOOL WriteLogAtFirstLine(TCHAR* pContent);    //將最近的日志寫在最前面    
    void SetLogSize(int iSize);

private:
    HANDLE m_hFile;
    
string m_strFileName;
    
string m_strFormat; 
    CRITICAL_SECTION m_cs;                
//臨界區
    BOOL m_bInit;                            //初始化標志位
    int m_iSize;                                //文件大小    -- KB計算

    
string GetTimeStr();
};

.cpp文件
/***************************************************
*文件名稱: Log_SDK.cpp
*功能說明: LogSDK的實現文件
*創建時間: 09.10.31
*文件作者: zip
***************************************************
/
#include 
"StdAfx.h"
#include 
".\log_sdk.h"

LogSDK::LogSDK(
string strFileName)
{
    m_bInit 
= FALSE;
    m_strFileName 
= strFileName;
    m_iSize 
= 20;    //默認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 , 
"打開文件失敗 , 錯誤代碼:%d" , dwErrorCode);
        
//AfxMessageBox(szErrMsg);
        MessageBox(NULL , szErrMsg , _T("警告") ,IDOK);
        
return FALSE;
    }
    ::InitializeCriticalSection(
&m_cs);    //初始化臨界區
    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);    //移動文件指針
        SetEndOfFile(m_hFile);//清空文件
    }
    
string strContent(pContent);
    strContent 
+= "\r\n";

    BOOL bRet 
= TRUE;
    ::EnterCriticalSection(
&m_cs);
    SetFilePointer(m_hFile , 
0 , NULL , FILE_END);    //移動到文件末尾
    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 , 
"寫入日志文件失敗 , 錯誤代碼:%d" , dwErrorCode);        
        MessageBox(NULL , szErrMsg , _T(
"發生了嚴重的錯誤") , IDOK);
        bRet 
= FALSE;    //此處不用返回  還要釋放臨界區
    }
    ::LeaveCriticalSection(
&m_cs);

    
return bRet;
}

//帶有時間戳的日志
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);    //移動到文件末尾
    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 , 
"寫入日志文件失敗 , 錯誤代碼:%d" , dwErrorCode);        
        MessageBox(NULL , szErrMsg , _T(
"發生了嚴重的錯誤") , IDOK);
        bRet 
= FALSE;    //此處不用返回  還要釋放臨界區
    }
    ::LeaveCriticalSection(
&m_cs);

    
return bRet;
}

//返回格式化的時間字符串
string LogSDK::GetTimeStr()
{
    SYSTEMTIME sys;
    ::GetLocalTime(
&sys);    //獲取當前系統時間
    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 李佳 閱讀(1190) 評論(1)  編輯 收藏 引用 所屬分類: WIN32 應用開發

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

  回復  更多評論
  
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿

隨筆分類

隨筆檔案

文章檔案

相冊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品白丝jk黑袜喷水| 精品va天堂亚洲国产| 蜜臀99久久精品久久久久久软件 | 欧美在线视频播放| 亚洲国内高清视频| 久久99在线观看| 香蕉久久夜色精品国产| 欧美另类视频| 亚洲高清不卡一区| 国产一区二区精品在线观看| 99精品福利视频| 日韩视频二区| 欧美插天视频在线播放| 免费成人激情视频| 伊人久久成人| 久久精品国产96久久久香蕉| 久久精品亚洲精品国产欧美kt∨| 国产精品国产三级国产普通话蜜臀| 亚洲七七久久综合桃花剧情介绍| 亚洲电影免费观看高清| 久久婷婷一区| 欧美www视频在线观看| 好看的av在线不卡观看| 小辣椒精品导航| 久久久另类综合| 激情综合色综合久久| 久久久久久久999精品视频| 久久久久久久综合色一本| 国产婷婷成人久久av免费高清 | 国产日韩在线亚洲字幕中文| 亚洲一区久久| 欧美一区二区三区在线| 国产午夜精品一区理论片飘花| 亚洲欧美精品伊人久久| 久久国产加勒比精品无码| 国产一区99| 久久青草久久| 最近中文字幕mv在线一区二区三区四区| 最新高清无码专区| 欧美日韩高清免费| 亚洲制服av| 久久一二三区| 日韩视频免费| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲欧美日韩第一区| 久久婷婷久久一区二区三区| 最新亚洲一区| 国产精品老女人精品视频| 欧美一级播放| 亚洲国产高清aⅴ视频| 亚洲一区二区欧美| 国产午夜精品久久| 久久综合色影院| 99国产精品视频免费观看一公开| 午夜精品一区二区在线观看| 伊人狠狠色j香婷婷综合| 欧美精品不卡| 亚洲欧美在线视频观看| 欧美第一黄色网| 亚洲欧美日韩一区二区在线| 国外成人网址| 欧美日韩一区二区三区在线视频| 性久久久久久| 日韩亚洲欧美一区二区三区| 久久黄色级2电影| 99这里只有精品| 国语自产精品视频在线看抢先版结局| 欧美高清在线一区| 午夜精品久久久久影视| 亚洲欧洲视频在线| 久久久综合精品| 亚洲男女自偷自拍图片另类| 在线日韩视频| 国产日韩欧美在线视频观看| 欧美成人精品在线播放| 欧美在线视频播放| 一本色道久久88综合日韩精品| 蜜臀av性久久久久蜜臀aⅴ| 亚洲一区观看| 日韩网站免费观看| 在线成人欧美| 国产一区99| 国产精品久久久久9999高清| 欧美成人一品| 久久久久久久久伊人| 亚洲一区二区影院| 亚洲精选视频在线| 亚洲第一精品久久忘忧草社区| 久久久久久久久伊人| 亚洲欧美日韩成人| 99天天综合性| 91久久精品久久国产性色也91| 国语自产偷拍精品视频偷| 国产精品丝袜白浆摸在线| 欧美日韩在线直播| 欧美日韩aaaaa| 久久激情五月丁香伊人| 午夜宅男欧美| 亚洲欧美日韩精品久久亚洲区| 日韩午夜黄色| 亚洲人被黑人高潮完整版| 欧美大片在线看免费观看| 美女爽到呻吟久久久久| 久久久www| 久久天天躁狠狠躁夜夜av| 久久精品国产精品亚洲精品| 欧美在线视频全部完| 午夜精品影院| 欧美在线资源| 久久免费视频在线观看| 久热这里只精品99re8久| 久久久综合香蕉尹人综合网| 久久在线免费观看视频| 久久视频免费观看| 久热这里只精品99re8久| 裸体一区二区三区| 老司机aⅴ在线精品导航| 免费在线看成人av| 欧美激情亚洲自拍| 亚洲美女毛片| 亚洲午夜精品久久久久久浪潮| 亚洲一区二区视频在线| 羞羞答答国产精品www一本 | 国产精品专区h在线观看| 国产精品自在在线| 国语自产精品视频在线看一大j8 | 亚洲国产成人精品久久| 最新中文字幕一区二区三区| 亚洲美女在线视频| 亚洲视频在线播放| 久久精品理论片| 欧美成人免费小视频| 欧美日韩一区二区三区免费看| 国产精品高潮呻吟| 国产亚洲欧美日韩一区二区| 亚洲第一成人在线| 一区二区三区欧美在线观看| 午夜精品成人在线视频| 久久综合成人精品亚洲另类欧美| 欧美韩日一区| 亚洲一区二区三区视频| 久久午夜色播影院免费高清| 欧美日韩精品免费观看视频完整| 国产精品日产欧美久久久久| 亚洲第一色在线| 亚洲调教视频在线观看| 久久香蕉国产线看观看av| 亚洲黄色小视频| 亚洲欧美久久久久一区二区三区| 久久婷婷国产综合尤物精品| 欧美日韩无遮挡| 精品成人久久| 亚洲欧美综合另类中字| 欧美肥婆bbw| 亚洲欧美福利一区二区| 欧美激情中文不卡| 国模私拍视频一区| 亚洲一区二区三区在线观看视频| 免费日本视频一区| 99pao成人国产永久免费视频| 欧美中文字幕视频| 欧美日韩在线播放三区| 亚洲国产精品第一区二区三区| 亚洲欧美日本视频在线观看| 亚洲国产美女精品久久久久∴| 亚洲欧美视频在线| 欧美日韩精品伦理作品在线免费观看| 一区二区在线观看视频| 亚洲欧美精品| 国产精品成人播放| 国产精品亚洲产品| 亚洲三级免费观看| 亚洲欧美日韩人成在线播放| 欧美成人精品三级在线观看| 韩国在线视频一区| 欧美在线在线| 9色国产精品| 欧美日本一区| 日韩午夜av| 亚洲国产日韩欧美一区二区三区| 久久超碰97人人做人人爱| 国产精品一区二区久久久久| 亚洲特黄一级片| 99riav1国产精品视频| 欧美国产免费| 亚洲精品视频免费在线观看| 欧美激情第1页| 蜜臀av一级做a爰片久久| 伊人久久亚洲热| 母乳一区在线观看| 久久久亚洲一区| 亚洲国产成人精品久久| 免费观看久久久4p| 久久影视精品| 亚洲精品永久免费| 亚洲欧洲日产国产综合网| 欧美精品乱人伦久久久久久 | 亚洲三级影院| 欧美日韩福利| 亚洲欧美清纯在线制服|