调试过程中需要打印出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");