C++ Log日志類輕量級支持格式化輸出變量實現(xiàn)代碼
更新時間:2019年04月07日 21:28:13 投稿:mdxy-dxy
這篇文章主要介紹了C++ Log日志類輕量級支持格式化輸出變量實現(xiàn)代碼,需要的朋友可以參考下
CLog 頭 代碼很簡單 如果需要的直接Ctrl+C ----Ctrl+V 即可
#ifndef __CLOG__ #define __CLOG__ #include <windows.h> #include <string> #include <fstream> #include <tchar.h> #include <ctime> class CLog { public: CLog(); CLog(const std::string LogFile); ~CLog(); template <class T> static void WriteLog(T x); //支持格式化輸出多參數(shù)輸出 static void WriteLogFormat(const char* format, ...); private: static std::string GetFilePath(); std::string m_LogFilePath; static std::string GetSystemTimes(); static bool IsPathExist(const std::string FilePath); }; //支持輸出int double 文本 template <class T> void CLog::WriteLog(T x) { std::fstream of(GetFilePath(), std::ios::app); if (!of.is_open())return; of.seekp(std::ios::end); //設(shè)置文件指針到文件尾部 of << GetSystemTimes() <<_T("line: ")<<__LINE__<<_T(" value: ")<< x << std::endl; of.close(); //關(guān)閉文件; } #endif
CLog.cpp
#include "Log.h" CLog::CLog() :m_LogFilePath("") { m_LogFilePath = GetFilePath(); if (IsPathExist(m_LogFilePath)) DeleteFile(m_LogFilePath.c_str()); } CLog::CLog(const std::string LogFile) :m_LogFilePath(LogFile) { if (IsPathExist(m_LogFilePath)) DeleteFile(m_LogFilePath.c_str()); } CLog::~CLog() { } void CLog::WriteLogFormat(const char* format, ...) { va_list arglist; std::string strArgData; char szBuffer[0x1024]; ZeroMemory(szBuffer, 0x1024); va_start(arglist, format); vsprintf_s(szBuffer, format, arglist); va_end(arglist); strArgData = szBuffer; std::fstream of(GetFilePath(), std::ios::app); if (!of.is_open())return; of << GetSystemTimes() << " Line: " << __LINE__ << " Value: " << strArgData << std::endl; of.close(); } std::string CLog::GetFilePath() { std::string FlieTmp; TCHAR szPath[MAX_PATH]; ::ZeroMemory(szPath, MAX_PATH); if (!::GetCurrentDirectory(MAX_PATH, szPath))return FlieTmp; FlieTmp = szPath; FlieTmp += _T("\\log.txt"); return FlieTmp; } std::string CLog::GetSystemTimes() { time_t Time; CHAR strTime[MAX_PATH]; ZeroMemory(strTime, MAX_PATH); time(&Time); tm t; localtime_s(&t, &Time); strftime(strTime, 100, _T("%Y-%m-%d %H:%M:%S "), &t); std::string strTimes = strTime; return strTimes; } bool CLog::IsPathExist(const std::string FilePath) { DWORD dwAttribute = ::GetFileAttributes(FilePath.c_str()); return dwAttribute != INVALID_FILE_ATTRIBUTES; }
好了這篇文章就介紹到這了,需要的朋友可以的參考一下。
相關(guān)文章
COLORREF,COLOR,RGB,CString的轉(zhuǎn)化總結(jié)分析
實際的軟件開發(fā)過程中,常需要用到非.net平臺的代碼。這時候就可能碰到ColorRef(也就是以int類型代表的顏色值或是以DWORD值表示的顏色)。這跟.net平臺下的顏色的相互轉(zhuǎn)換MS并沒有直接實現(xiàn)2013-09-09C++數(shù)據(jù)結(jié)構(gòu)之AVL樹的實現(xiàn)
AVL樹是高度平衡的而二叉樹,它的特點是AVL樹中任何節(jié)點的兩個子樹的高度最大差別為1,本文主要給大家介紹了C++如何實現(xiàn)AVL樹,需要的朋友可以參考下2022-06-06VSCode與Keil聯(lián)合開發(fā)STM32的流程
這篇文章主要介紹了VSCode與Keil聯(lián)合開發(fā)STM32的流程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02Qt掃盲篇之QRegularExpression正則匹配總結(jié)
QRegularExpression是Qt5.0引進的,修復了很多bug,提高了效率,使用時建議使用QRegularExpression,下面這篇文章主要給大家介紹了關(guān)于Qt掃盲篇之QRegularExpression正則匹配的相關(guān)資料,需要的朋友可以參考下2023-03-03