![編寫(xiě)一個(gè)的日志組件_第1頁(yè)](http://file4.renrendoc.com/view/f9d8f41bcece86c931acc51c45f1783d/f9d8f41bcece86c931acc51c45f1783d1.gif)
![編寫(xiě)一個(gè)的日志組件_第2頁(yè)](http://file4.renrendoc.com/view/f9d8f41bcece86c931acc51c45f1783d/f9d8f41bcece86c931acc51c45f1783d2.gif)
![編寫(xiě)一個(gè)的日志組件_第3頁(yè)](http://file4.renrendoc.com/view/f9d8f41bcece86c931acc51c45f1783d/f9d8f41bcece86c931acc51c45f1783d3.gif)
![編寫(xiě)一個(gè)的日志組件_第4頁(yè)](http://file4.renrendoc.com/view/f9d8f41bcece86c931acc51c45f1783d/f9d8f41bcece86c931acc51c45f1783d4.gif)
![編寫(xiě)一個(gè)的日志組件_第5頁(yè)](http://file4.renrendoc.com/view/f9d8f41bcece86c931acc51c45f1783d/f9d8f41bcece86c931acc51c45f1783d5.gif)
版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025至2030年中國(guó)液相自動(dòng)切換器數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 2025至2030年中國(guó)海米數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 2025年中國(guó)鐵藝水果籃市場(chǎng)調(diào)查研究報(bào)告
- 2025年中國(guó)航空用品市場(chǎng)調(diào)查研究報(bào)告
- 2025年中國(guó)充消敏檢查驗(yàn)證儀市場(chǎng)調(diào)查研究報(bào)告
- 2025至2030年中國(guó)糖酰氯數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 2025至2030年中國(guó)電風(fēng)扇不可拆線插頭數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 2025至2030年中國(guó)水箱和水槽用承燒板數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 2025至2030年中國(guó)化纖針織布數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 2025至2030年中國(guó)全透明石材膠數(shù)據(jù)監(jiān)測(cè)研究報(bào)告
- 介紹人提成方案
- 天津在津居住情況承諾書(shū)
- PHOTOSHOP教案 學(xué)習(xí)資料
- 初中數(shù)學(xué)教學(xué)“教-學(xué)-評(píng)”一體化研究
- 2012年安徽高考理綜試卷及答案-文檔
- 《游戲界面設(shè)計(jì)專(zhuān)題實(shí)踐》課件-知識(shí)點(diǎn)5:圖標(biāo)繪制準(zhǔn)備與繪制步驟
- 自動(dòng)扶梯安裝過(guò)程記錄
- MOOC 材料科學(xué)基礎(chǔ)-西安交通大學(xué) 中國(guó)大學(xué)慕課答案
- 智慧供熱管理系統(tǒng)方案可行性研究報(bào)告
- 帕金森病的言語(yǔ)康復(fù)治療
- 中國(guó)城市居民的健康意識(shí)和生活方式調(diào)研分析報(bào)告
評(píng)論
0/150
提交評(píng)論