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



转载于:https://www.cnblogs.com/zhfuliang/archive/2012/03/04/2379181.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值