调试过程中Log信息的存储(写文件操作)

调试过程中需要打印出Log信息,很多人可能都遇到过,可能有些第三方的库提供给大家使用,但很多人会嫌麻烦而不用,我也常常因为第三方库麻烦而不用,所以就谢了一个很简单打印Log的函数

头文件部分

#include <string>
#include <fstream>
#include<ctime>
#include <windows.h>
#define LOG_ADD_TIME //如果需要加入时间则需要声明此句,如果不需要加入时间信息则可以去掉此句
using namespace std;

函数实现部分

string GetTime()
{
	SYSTEMTIME sys; 
	GetLocalTime(&sys);
	const int MAX_NUM = 255;
	char timeArray[MAX_NUM]={0};
	sprintf_s(timeArray, MAX_NUM, "%d-%d-%d %d:%d:%d:%d ", sys.wYear,sys.wMonth, sys.wDay, sys.wHour,sys.wMinute,
		sys.wSecond, sys.wMilliseconds);
	string strTime(timeArray);
	return strTime;
}

bool Log(const string &str, const string &strFileName)
{
	string strContent = str;
	ofstream logFile(strFileName, ios::app);
	if (!logFile)
	{
		return false;
	}
#ifdef LOG_ADD_TIME
	string strTime = GetTime();
	strContent = strTime + strContent;
#endif
	logFile << strContent << endl;
	return true;
}
  
bool Log(const string &str)
{
	return Log(str, "LogFile.txt");
}

  

调用的时候,可以自己填入需要写入的文件名,也可以不填入使用默认的的文件名

        Log("Start", "E:\\a.txt");
for (int i=0; i<100; ++i)
{
Log("Hello world");
}
Log("End", "E:\\a.txt");



posted @ 2012-03-04 13:07  小小亮FLY  阅读(374)  评论(0编辑  收藏  举报