我是靠谱客的博主 俏皮帅哥,最近开发中收集的这篇文章主要介绍C++ 写日志文件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"rn", 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"rn", 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("rn", 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("rn", sizeof(char), 2, fp);
			fclose(fp);
		}
	}
 

 

最后

以上就是俏皮帅哥为你收集整理的C++ 写日志文件C++ 写日志文件的全部内容,希望文章能够帮你解决C++ 写日志文件C++ 写日志文件所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部