編寫(xiě)一個(gè)的日志組件_第1頁(yè)
編寫(xiě)一個(gè)的日志組件_第2頁(yè)
編寫(xiě)一個(gè)的日志組件_第3頁(yè)
編寫(xiě)一個(gè)的日志組件_第4頁(yè)
編寫(xiě)一個(gè)的日志組件_第5頁(yè)
已閱讀5頁(yè),還剩2頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

本文格式為Word版,下載可任意編輯——編寫(xiě)一個(gè)的日志組件編寫(xiě)一個(gè)通用的日志組件

編寫(xiě)程序?qū)こR敵鋈罩?,這樣程序假使運(yùn)行出錯(cuò),就可以通過(guò)日志查看出錯(cuò)的原因。下面就利用VC++編寫(xiě)一個(gè)通用的日志組件。當(dāng)一個(gè)新的項(xiàng)目來(lái)臨時(shí),就可以直接使用了。該組件為windows環(huán)境下標(biāo)準(zhǔn)的動(dòng)態(tài)鏈接庫(kù),除了VC++外,其他語(yǔ)言如VB,C#也可以調(diào)用。

在頭文件里定義幾個(gè)輸出接口//錯(cuò)誤類(lèi)型enumEM_LOG_TYPE{LT_TRACE=1,LT_NORMAL,LT_WARN,LT_ERROR};//設(shè)置日志文件的目錄WSLOG_APIboolSetLogFilePath(LPCTSTRptszFilePath);//寫(xiě)日志W(wǎng)SLOG_APIboolWriteLog(EM_LOG_TYPEemLogType,LPCTSTRptszInfo);//關(guān)閉日志功能的輸出WSLOG_APIboolCloseLogFile();

實(shí)現(xiàn)代碼:boolg_bFileOpen=false;FILE*g_pFile=0;

TCHARg_tszErrorInfo[100]={0};

TCHARg_tszLogFilePath[_MAX_DIR]={0};CRITICAL_SECTIONg_cs;TCHARg_tszOldFileName[50]={0};

WSLOG_APIboolSetLogFilePath(LPCTSTRptszLogFilePath){

//假使是多層,需要?jiǎng)?chuàng)立各層文件夾boolbRet;intstartPos=0;

constTCHAR*pos=_tcsstr(ptszLogFilePath,_T(\while(pos){

TCHARcTmpValue[_MAX_DIR];memset(cTmpValue,0,_MAX_DIR);

intiLen=_tcslen(ptszLogFilePath);if(iLen>_MAX_DIR){}

_tcscpy(g_tszErrorInfo,_T(\路徑太長(zhǎng)!\returnfalse;

}

}

_tcsncpy(cTmpValue,ptszLogFilePath,pos-ptszLogFilePath+1);bRet=SetCurrentDirectory(cTmpValue);if(!bRet)//文件夾不存在,需要建立{}

startPos=pos-ptszLogFilePath+1;

pos=_tcsstr(ptszLogFilePath+startPos,_T(\

BOOLbRet2=CreateDirectory(cTmpValue,NULL);if(FALSE==bRet2){}

memset(g_tszErrorInfo,0,100*sizeof(TCHAR));_tcscpy(g_tszErrorInfo,_T(\文件夾創(chuàng)立失敗!\returnfalse;

::CreateDirectory(ptszLogFilePath,NULL);_tcscpy(g_tszLogFilePath,ptszLogFilePath);::InitializeCriticalSection(returntrue;

WSLOG_APIboolWriteLog(EM_LOG_TYPEemLogType,LPCTSTRptszInfo){

//先開(kāi)啟文件

TCHARtszFileName[MAX_PATH]={0};if(g_pFile==NULL){

TCHARtszDate[50]={0};

_stprintf(tszDate,_T(\_tcscpy_s(tszFileName,MAX_PATH,g_tszLogFilePath);SYSTEMTIMEst;GetLocalTime(

::EnterCriticalSection(//線程同步if(_tcslen(g_tszLogFilePath)==0){}

_tcscpy(g_tszErrorInfo,_T(\未指定日志存放目錄!\returnfalse;

}

intiLen=_tcslen(g_tszLogFilePath);

if(g_tszLogFilePath[iLen-1]==_T('\\\\')||g_tszLogFilePath[iLen-1]==_T('/'))else{}

g_pFile=_tfopen(tszFileName,_T(\

_tcscat(tszFileName,_T(\_tcscat(tszFileName,tszDate);_tcscat(tszFileName,tszDate);

else//日志文件已經(jīng)開(kāi)啟{}//寫(xiě)日志

charszTime[50]={0};

sprintf(szTime,\

st.wHour,st.wMinute,st.wSecond,st.wMilliseconds);fwrite(szTime,strlen(szTime),1,g_pFile);charszLogType[50]={0};switch(emLogType){

TCHARtszDate[50]={0};

_stprintf(tszDate,_T(\if(_tcscmp(tszDate,g_tszOldFileName)!=0)//不一樣,說(shuō)明日期變了{(lán)}

fclose(g_pFile);g_pFile=NULL;

_tcscpy_s(tszFileName,MAX_PATH,g_tszLogFilePath);intiLen=_tcslen(g_tszLogFilePath);

if(g_tszLogFilePath[iLen-1]==_T('\\\\')||g_tszLogFilePath[iLen-1]==_T('/'))else{}

g_pFile=_tfopen(tszFileName,_T(\_tcscpy(g_tszOldFileName,tszDate);

_tcscat(tszFileName,_T(\_tcscat(tszFileName,tszDate);_tcscat(tszFileName,tszDate);

caseLT_NORMAL:}

fwrite(szLogType,strlen(szLogType),1,g_pFile);intiLen=_tcslen(ptszInfo);//intiLen2=_tcsclen(ptszInfo);

strcpy(szLogType,\break;

strcpy(szLogType,\break;

strcpy(szLogType,\break;

strcpy(szLogType,\break;

caseLT_TRACE:

caseLT_WARN:

caseLT_ERROR:

#ifdef_UNICODE}

::LeaveCriticalSection(returntrue;

fwrite(\fflush(g_pFile);

fwrite(pszInfo,strlen(pszInfo),1,g_pFile);delete[]pszInfo;

fwrite(ptszInfo,_tcslen(ptszInfo),1,g_pFile);

DWORDdwNum=WideCharToMultiByte(CP_ACP,0,ptszInfo,-1,NULL,0,NULL,NULL);char*pszInfo;

pszInfo=newchar[dwNum+1];if(!pszInfo){}

memset(pszInfo,0,dwNum+1);

::WideCharToMultiByte(CP_ACP,0,ptszInfo,-1,pszInfo,dwNum,NULL,NULL);

_tcscpy(g_tszErrorInfo,_T(\內(nèi)存不足!\::LeaveCriticalSection(returnfalse;

#else#endif

WSLOG_APIboolCloseLogFile(){}編譯工程后,會(huì)生成wsLog.dll組件。

利用VC++的MFC對(duì)話框程序測(cè)試組件。先添加頭文件#include\#pragmacomment(lib,\)在對(duì)話框上添加一編輯框和按鈕,然后在按鈕的單擊事件里添加代碼:voidCVCTestDlg::OnBnClickedWrite(){}運(yùn)行結(jié)果如下:

SetLogFilePath(_T(\));CS

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論