调试过程中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");