资源简介
用于MFC程序日志记录类,方面错误的查找

代码片段和文件信息
#include “StdAfx.h“
#include “Log.h“
#define LOG_EVENT _T(“Global\\ChyLogWrite“)
CString CLog::s_strLogFile = _T(““);
CString CLog::s_strLogPrefix = _T(““);
CString CLog::s_errorInfo=_T(““);
HANDLE CLog::s_hWriteEvent = NULL;
CLog::CLog(void)
{
}
CLog::~CLog(void)
{
}
//设置路径和名称分为两种模式
//如果给出的不是绝对路径:在EXE所在的目录下,新建一个LOG文件夹,log文件夹下日志文件名称为SMMS2014-10-28.log
//如果给出的是绝对路径:则以绝对路径为准。
short CLog::SetLogFile(LPCTSTR strPath)
{
//如果给的路径为空,则设置为xxx.log目录为EXE同目录
if (strPath==NULL)
{
// 得到当前的文件名
CString strFileName;
GetModuleFileName(AfxGetInstanceHandle()strFileName.GetBuffer(_MAX_PATH)_MAX_PATH);
strFileName.ReleaseBuffer();
// 得到当前目录
strFileName.Replace(“.exe““.log“);
s_strLogFile=strFileName;
}
else
{
s_strLogFile.Format(_T(“%s.log“)strPath);
}
return 1;
}
short CLog::SetPrefix(LPCTSTR strPrefix)
{
if(strPrefix && strPrefix[0])
{
s_strLogPrefix = strPrefix;
}
return 1;
}
//清空当前的文件,新建
void CLog::CreateNewFile()
{
//-打开关闭文件-
if(s_strLogFile.IsEmpty())
SetLogFile(NULL);
CStdioFile file;
if(!file.Open(s_strLogFile CFile::modeCreate))
{
CString str;
str.Format(_T(“打开文件失败!路径为:%s“)s_strLogFile);
AfxMessageBox(str);
exit(0);
}
file.Close();
}
short CLog::GetDugInfo(LPCSTR pDugInfo/* =NULL */)
{
// char file[16];
//// char func[16];
// int line;
// sprintf(file__FILE__); //文件名
//// sprintf(func__FUNCTION__);//函数名
// line=__LINE__; //行号
s_errorInfo.Format(_T(“%s“)pDugInfo);
return 1;
}
short CLog::WriteMsg(LPCTSTR strFormat)
{
//--
if(s_hWriteEvent==NULL)
{
s_hWriteEvent = OpenEvent(0 FALSELOG_EVENT);
if(s_hWriteEvent==NULL)
s_hWriteEvent = CreateEvent(NULL FALSE TRUE LOG_EVENT);
}
WaitForSingleobject(s_hWriteEvent INFINITE);
//-打开关闭文件-
if(s_strLogFile.IsEmpty())
SetLogFile(NULL);
CStdioFile file;
if(file.Open(s_strLogFile CFile::modeCreate|CFile::modeNoTruncate|CFile::modeWrite))
{
file.SeekToEnd();
CString strPart_Time;
{
SYSTEMTIME sysTime = {0};
GetLocalTime(&sysTime);
strPart_Time.Format(_T(“\n%2d-%2d-%2d %2d:%2d:%2d“)
sysTime.wYearsysTime.wMonthsysTime.wDaysysTime.wHour sysTime.wMinute sysTime.wSecond);
}
CString str;
str=strPart_Time+_T(“\t“)+s_errorInfo;
file.WriteString(str);
s_errorInfo=““;
str=_T(“\n[“)+s_strLogPrefix+_T(“]“)+strFormat+_T(“\n“);
file.WriteString(str);
file.Close();
}
SetEvent(s_hWriteEvent);
return 1;
}
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 2704 2014-12-30 14:50 Log.cpp
文件 726 2014-12-30 14:41 Log.h
----------- --------- ---------- ----- ----
3430 2
- 上一篇:数据结构算法与应用 c++语言描述(第二版代码
- 下一篇:LBM溃坝算例代码
相关资源
- 基于MFC的TCP调试助手源码95706
- 基于mfc的多线程文件传输
- MFC数字钟(基于VC6.0)
- VC++MFC小游戏实例教程(实例)+MFC类库
- 用C语言实现高效日志
- ChartCtrl控件库(可在VS2019中使用)
- 商品库存管理系统 C++ MFC
- mfc 调用redis
- MFC视频播放器源码(支持avi/wma/mp3等格
- mfc绘图大全(画直线、矩形、椭圆)
- MFC控件重绘
- hook,捕获所有案件,查找所有窗口,
- (学习)VS2010之MFC入门到精通教程
- MFC文档_视图_框架_模板结构体系深入
- 简单员工管理系统(适合初学MFC)
- MFC五子棋游戏
- MFC UDP编程
- MFC的异步网络通讯应用程序
- C++MFC模块讲解,黑发程序员课程整理
- 一个简单而强大的基于MFC的web server源
- 基于MFC的VC++仿QQ浏览器源码(雏形)
- MFCaccess.rar
- VC++MFC课程设计的学生成绩管理系统
- MFC 日历控件 万年历 Calendar自绘
- CrystalDiskInfo-HDD/SSD硬盘信息,SMART信息
- MFC自定义界面HUI,高效简单,含详细
- 仿射密码-Affine cipher
- c++MFC车牌自动识别定位,只能定位和
- mfc+sql 酒店客房管理系统
- 基于图割的图像分割OpenCV+MFC实现
评论
共有 条评论