綾葷殑浣跨敤涔熷緢綆鍗?nbsp; 鍒濆鍖栫殑鏃跺欎紶閫掍竴涓棩蹇楀悕縐?nbsp;
鐒跺悗鍦ㄩ渶瑕佸啓鏃ュ織鐨勫湴鏂?鐩存帴璋冪敤榪欎釜瀵硅薄鐨刉riteLog鍑芥暟浼犻掍竴涓瓧絎︿覆榪涘幓灝辮浜?br>濡傛灉闇瑕佹椂闂存埑 鍒欒皟鐢╓riteLogWithTime鍑芥暟 涓鏍風殑鎺ュ彛
鏀寔璁劇疆鏃ュ織澶у皬 SetLogSize() //KB璁$畻
浠g爜寰堢畝鍗?nbsp; 涓鐧炬潵琛?nbsp; 涓嶈繃鐢ㄧ潃榪樼畻鎸烘柟渚跨殑 涓嬪崍灝辯敤榪欎釜鏃ュ織綾繪壘鍒頒簡涓涓互鍓嶅伐紼嬩腑鐨凷QL鐩稿叧鑱旂殑BUG 鍛靛懙
.h鏂囦歡
/*****************************************************
*鏂囦歡鍚嶇О: Log_SDK.h
*鍔熻兘璇存槑: 浣跨敤SDK + STL閲嶅啓鐨勪竴涓棩蹇楃被 澧炲姞鍙Щ妞嶆?br>*鍒涘緩鏃墮棿: 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); //姣忔鍐欎竴琛?nbsp;涓斿甫鏃墮棿
BOOL WriteLogAtFirstLine(TCHAR* pContent); //灝嗘渶榪戠殑鏃ュ織鍐欏湪鏈鍓嶉潰
void SetLogSize(int iSize);
private:
HANDLE m_hFile;
string m_strFileName;
string m_strFormat;
CRITICAL_SECTION m_cs; //涓寸晫鍖?/span>
BOOL m_bInit; //鍒濆鍖栨爣蹇椾綅
int m_iSize; //鏂囦歡澶у皬 -- KB璁$畻
string GetTimeStr();
};
.cpp鏂囦歡
/***************************************************
*鏂囦歡鍚嶇О: Log_SDK.cpp
*鍔熻兘璇存槑: LogSDK鐨勫疄鐜版枃浠?br>*鍒涘緩鏃墮棿: 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 , "鎵撳紑鏂囦歡澶辮觸 , 閿欒浠g爜:%d" , dwErrorCode);
//AfxMessageBox(szErrMsg);
MessageBox(NULL , szErrMsg , _T("璀﹀憡") ,IDOK);
return FALSE;
}
::InitializeCriticalSection(&m_cs); //鍒濆鍖栦復鐣屽尯
m_bInit = TRUE;
return TRUE;
}
//鏅氱殑鍐欐棩蹇?/span>
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); //縐誨姩鍒版枃浠舵湯灝?/span>
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 , "鍐欏叆鏃ュ織鏂囦歡澶辮觸 , 閿欒浠g爜:%d" , dwErrorCode);
MessageBox(NULL , szErrMsg , _T("鍙戠敓浜嗕弗閲嶇殑閿欒") , IDOK);
bRet = FALSE; //姝ゅ涓嶇敤榪斿洖 榪樿閲婃斁涓寸晫鍖?/span>
}
::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); //縐誨姩鍒版枃浠舵湯灝?/span>
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 , "鍐欏叆鏃ュ織鏂囦歡澶辮觸 , 閿欒浠g爜:%d" , dwErrorCode);
MessageBox(NULL , szErrMsg , _T("鍙戠敓浜嗕弗閲嶇殑閿欒") , IDOK);
bRet = FALSE; //姝ゅ涓嶇敤榪斿洖 榪樿閲婃斁涓寸晫鍖?/span>
}
::LeaveCriticalSection(&m_cs);
return bRet;
}
//榪斿洖鏍煎紡鍖栫殑鏃墮棿瀛楃涓?/span>
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;
}
涔熷彲浠ョ畻閿葷偧涓涓婣PI鐨勬搷浣滃惂...

]]>