C++ 写日志文件

C++ 写日志文件


//在指定文件路径写入指定信息,unicode版本
	void CLog::WriteLog(const wchar_t* filePath, const wchar_t* text)
	{
		//首先判断文件是否存在,如果不存在则创建,并在开头加入0xfeff;如果存在则直接写入
		if (_waccess(filePath, 0) == -1)
		{
			FILE* fp;
			_wfopen_s(&fp, filePath, L"wb");
			if (fp != NULL)
			{
				uint16_t wSignature = 0xFEFF;
				fwrite(&wSignature, 2, 1, fp);
				SYSTEMTIME st;
				GetLocalTime(&st);
				wchar_t buf[128] = { 0 };
				swprintf_s(buf, 128, L"%04d%02d%02d %02d:%02d:%02d:%03d	", st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond, st.wMilliseconds);
				fwrite(buf, sizeof(wchar_t), wcslen(buf), fp);
				fwrite(text, sizeof(wchar_t), wcslen(text), fp);
				fwrite(L"\r\n", sizeof(wchar_t), 2, fp);
				fclose(fp);
			}
		}
		else 
		{
			FILE* fp;
			_wfopen_s(&fp, filePath, L"ab");
			if (fp != NULL)
			{
				SYSTEMTIME st;
				GetLocalTime(&st);
				wchar_t buf[128] = { 0 };
				swprintf_s(buf, 128, L"%04d%02d%02d %02d:%02d:%02d:%03d	", st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond, st.wMilliseconds);
				fwrite(buf, sizeof(wchar_t), wcslen(buf), fp);
				fwrite(text, sizeof(wchar_t), wcslen(text), fp);
				fwrite(L"\r\n", sizeof(wchar_t), 2, fp);
				fclose(fp);
			}
		}
		
	}
	//在指定文件路径写入指定信息,ANSI版本
	void CLog::WriteLog(const char* filePath, const char* text)
	{
		FILE* fp;
		fopen_s(&fp, filePath, "a");
		if (fp != NULL)
		{
			SYSTEMTIME st;
			GetLocalTime(&st);
			char buf[128] = { 0 };
			sprintf_s(buf, 128, "%04d%02d%02d %02d:%02d:%02d:%03d ", st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond, st.wMilliseconds);
			fwrite(buf, sizeof(char), strlen(buf), fp);
			fwrite(text, sizeof(char), strlen(text), fp);
			fwrite("\r\n", sizeof(char), 2, fp);
			fclose(fp);
		}
	}
 
	//在指定文件路径写入指定信息,格式化字符串版本
	void CLog::WriteLogEx(const char* filePath, const char* const format, ...)
	{
		std::string tmp;
		va_list maker = NULL;
		va_start(maker, format);
		size_t numofchar = _vscprintf(format, maker);
		if (numofchar > tmp.capacity())
		{
			tmp.resize(numofchar + 1);
		}
		vsprintf_s((char*)tmp.data(), tmp.capacity(), format, maker);
		va_end(maker);
		std::string text = tmp;
 
		FILE* fp;
		fopen_s(&fp, filePath, "a");
		if (fp != NULL)
		{
			SYSTEMTIME st;
			GetLocalTime(&st);
			char buf[128] = { 0 };
			sprintf_s(buf, 128, "%04d%02d%02d %02d:%02d:%02d:%03d ", st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond, st.wMilliseconds);
			fwrite(buf, sizeof(char), strlen(buf), fp);
			fwrite(text.c_str(), sizeof(char), text.length(), fp);
			fwrite("\r\n", sizeof(char), 2, fp);
			fclose(fp);
		}
	}
 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值