C++ 多线程异步日志实现

//Coded by gdut cq in 2018.9.
#ifndef _LOG_H
#define _LOG_H
#include <vector>
#include <iostream>
DWORD WINAPI LogProc(LPVOID lpParaneter/*故障日志线程,非类函数!*/);
HANDLE hSemaphore;
CRITICAL_SECTION Jog_section; //临界区

class My_Log{
public:
	My_Log(CString file);
	~My_Log();
	bool Open();
	bool Write_to_log(CString logstr,CString levle);
	bool Write_to_save();

	CStdioFile _Log_File;
	CString _Log_Filename;
	std::vector<std::vector<CString> >::iterator iter;//二级指针
	std::vector<std::vector<CString> >::iterator begin_iter;//用于记录日志队列的起点
	std::vector<std::vector<CString> >::iterator end_iter;//用于记录日志队列的终点

	std::vector<CString>::iterator iiter;//一级指针
	std::vector<std::vector<CString> > Vector_Log_message;
	CString _Log_day_now;
	CString _writetext;

private:

	bool Printf_test(CString str);
	bool Clear_Log_before();
	bool Create_Log();
	CString Get_Log_time();
	
};
My_Log mylog("C:\\日志.log");

My_Log::My_Log(CString file)
{
	_Log_Filename=file;
	InitializeCriticalSection(&Jog_section);//初始化临界区变量
	hSemaphore = CreateSemaphore(NULL, 0, 2000, NULL);
	Vector_Log_message.resize(2000);
	iter=Vector_Log_message.begin();
	for(int i=0;i<2000;i++)
	{
		iter->resize(2);
		iter++;
	}
	iter=Vector_Log_message.begin();//开始的时候起点和终点都是0
	begin_iter=Vector_Log_message.begin();
	end_iter=Vector_Log_message.begin();
}

My_Log::~My_Log()
{
	_Log_File.Close();
}

bool My_Log::Open()
{
	CString readtext;
//	CString writetext;
	CTime time;
	time=CTime::GetCurrentTime();
	_Log_day_now=time.Format("%Y%m%d");//20180904
	if(_Log_File.Open(_T(_Log_Filename),CFile::modeCreate |CFile::modeReadWrite |
		CFile::typeText|CFile::modeNoTruncate))
	{
		while(_Log_File.ReadString(readtext))
		{
			if(atoi(_Log_day_now)-atoi(readtext.Left(8))<4)
			{
				_writetext+=readtext;
				_writetext+='\n';
			}
			else
				continue;
		}
		_Log_File.Close();
		if(_Log_File.Open(_T(_Log_Filename),CFile::modeCreate |CFile::modeReadWrite |
			CFile::typeText))
		{
		//	_Log_File.SeekToBegin();
			_Log_File.SeekToEnd();
			
			_Log_File.WriteString(_writetext);//此时wirtetext保存了以前的记录
		//	_Log_File.WriteString(_Log_day_now+'\n');
		}
		else
		{
			//open fail,do nothing;
			return 0;
		}
	}
	else
	{
		//open fail,do nothing;
		return 0;
	}
	
	HANDLE hThreadlog=CreateThread(NULL,0,LogProc,NULL,0,NULL);
	CloseHandle(hThreadlog);
	return 1;
}

bool My_Log::Write_to_log(CString logstr,CString levle)
{
  EnterCriticalSection(&Jog_section);	
  if(iter>=Vector_Log_message.end())
  {
	  return 0;
  }
  
  begin_iter=iter;//将最新的队列下表记录下来
  iiter=(*iter).begin();
  *iiter=logstr;
 //  mylog._Log_File.WriteString("20180901 进入writetolog,数据为:"+(*iiter)+'\n');
  iiter++;
  *iiter=levle;
  iter++;
//  mylog._Log_File.WriteString("20180901 进入writetolog,level为:"+(*iiter)+'\n');
  ReleaseSemaphore(hSemaphore, 1, NULL);//释放信号量 
  LeaveCriticalSection(&Jog_section);
  return 1;
}

DWORD WINAPI LogProc(LPVOID lpParaneter)
{
	CString jogstr;
	CString joglevel;
	std::vector<std::vector<CString> >::iterator checkiter;
	std::vector<std::vector<CString> >::iterator lastiter;
	while(1)
	{
		Sleep(10);
		WaitForSingleObject(hSemaphore, INFINITE);
	//	mylog._Log_File.WriteString("20180901 进入线程,level为: "+(*mylog.begin_iter)[1]);
		if((*mylog.begin_iter)[1]=="0"||(mylog.begin_iter-mylog.end_iter)>=10)
		{
			//mylog._Log_File.WriteString("20180901 进入写日志");
			lastiter=mylog.begin_iter;
			for(checkiter=mylog.end_iter;checkiter<=lastiter;checkiter++)
			{
				mylog._writetext=(*checkiter)[0];
				mylog._writetext+='\n';
				mylog._Log_File.SeekToEnd();		
				mylog._Log_File.WriteString(mylog._writetext);
			}
			if(lastiter<mylog.Vector_Log_message.end())
			{
				lastiter++;
				mylog.end_iter=lastiter;
			}
		}
// 
// 	    EnterCriticalSection(&Jog_section);
// 		LeaveCriticalSection(&Jog_section);
	}
	return 0;
}
#endif

 

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C++中,日志记录法是一种常见的调试技术,可以帮助我们在代码中插入记录,以便在程序运行时查看信息和错误。下面是一个简单的示例,演示如何在C++中使用日志记录法: ```cpp #include <iostream> #include <fstream> // 定义日志记录级别 enum LogLevel { LOG_LEVEL_DEBUG, LOG_LEVEL_INFO, LOG_LEVEL_WARNING, LOG_LEVEL_ERROR, }; // 定义日志记录器 class Logger { public: Logger() : m_logLevel(LOG_LEVEL_DEBUG) {} void setLogLevel(LogLevel level) { m_logLevel = level; } void log(LogLevel level, const std::string& message) { if (level < m_logLevel) { return; } std::ofstream file("log.txt", std::ios_base::app); file << "[" << getCurrentTime() << "] " << levelToString(level) << ": " << message << std::endl; } private: LogLevel m_logLevel; std::string getCurrentTime() { // 获取当前时间的代码 } std::string levelToString(LogLevel level) { // 将日志级别转换为字符串的代码 } }; int main() { Logger logger; // 设置日志记录级别 logger.setLogLevel(LOG_LEVEL_WARNING); // 记录日志 logger.log(LOG_LEVEL_DEBUG, "这是一个调试信息"); logger.log(LOG_LEVEL_INFO, "这是一个普通信息"); logger.log(LOG_LEVEL_WARNING, "这是一个警告信息"); logger.log(LOG_LEVEL_ERROR, "这是一个错误信息"); return 0; } ``` 在上面的代码中,我们定义了一个`Logger`类,它可以记录不同级别的日志。我们可以使用`setLogLevel()`方法来设置日志记录级别,然后使用`log()`方法来记录日志。在`log()`方法中,我们首先检查当前日志级别是否大于等于要记录的日志级别,如果是,就将日志记录到文件中。 在实际应用中,我们可能需要更复杂的日志记录器,例如支持多线程、异步日志等功能。但是,无论如何,日志记录法都是一种非常有用的调试技术,可以帮助我们更好地理解和调试代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值