资源简介
c++实现的日志类,能够按天写日志,并且超过一定大小进行备份,线程安全。
代码片段和文件信息
#include “StdAfx.h“
#include “Logger.h“
#include
#include
#include
using namespace HUALOG;
void Logger::writeLog(LOG_LEVEL level std::string msgstd::string filename int line)
{
CResGuard::CGuard gd(_logrs);
std::string fn= GetFileName(level);
time_t t;
time(&t);
struct tm tp;
localtime_s(&tp&t);
char now_str[100]={0};
strftime(now_str 100 “%Y-%m-%d %H:%M:%S“ &tp);
errno_t rt = fopen_s(&_fofn.c_str() “a“);
if (rt != 0) {
if(_fo)
fclose(_fo);
return;
}
fprintf_s(_fo “%s %s[%d] :%s\r\n“now_strfilename.c_str()line msg.c_str());
printf_s(“%s %s[%d] :%s\r\n“now_strfilename.c_str()line msg.c_str());
fseek(_fo0SEEK_END);
long position = ftell(_fo);
fclose(_fo);
if(position>_maxFileSize)
{
Rollover(fn);
}
}
std::string Logger::GetFileName(LOG_LEVEL level)
{
time_t t;
time(&t);
struct tm tp;
localtime_s(&tp&t);
char now_str[100]={0};
strftime(now_str 100 “%Y%m%d“ &tp);
std::string fn(now_str);
if(_date==““)
{
_date =fn;
_curIndex=0;
}
else if(_date!=fn)
{
_date =fn;
_curIndex=0;
}
fn.append(“_“);
switch (level)
{
case INFO_LOG:
fn+=“info.log“;
break;
case DEBUG_LOG:
fn+=“debug.log“;
break;
case WARNING_LOG:
fn+=“waring.log“;
break;
case ERROR_LOG:
fn+=“error.log“;
break;
}
if(_path!=““)
fn =_path+“\\“+fn;
return fn;
}
void Logger::Rollover(std::string& filename)
{
RolloverFiles(filename);
std::ostringstream source_oss;
std::ostringstream target_oss;
source_oss.str(““);
target_oss.str(““);
source_oss << filename;
target_oss << filename << “.“ << 1;
std::string const source (source_oss.str ());
std::string const target (target_oss.str ());
std::remove (target.c_str());
std::rename(source.c_str() target.c_str());
}
void Logger::RolloverFiles(std::string& filename)
{
std::ostringstream buffer;
long ret ;
if(_curIndex == _maxBackupIndex)
{
buffer< ret = std::remove(buffer.str().c_str());
}
std::ostringstream source_oss;
std::ostringstream target_oss;
for (int i = _curIndex; i >= 1; --i)
{
source_oss.str(““);
target_oss.str(““);
source_oss << filename << “.“ << i;
target_oss << filename << “.“ << (i+1);
std::string const source (source_oss.str ());
std::string const target (target_oss.str ());
ret =std::remove (target.c_str());
std::rename(source.c_str() target.c_str());
}
if(_curIndex!=(_maxBackupIndex-1))
_curIndex++;
}
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 1715 2011-10-27 11:16 Singleton.h
文件 2613 2011-10-28 09:38 Logger.cpp
文件 3251 2011-10-28 09:47 Logger.h
----------- --------- ---------- ----- ----
7579 3
相关资源
- 用C++栈写的中缀表达式求解
- MFC视频播放器(带播放列表VC++6.0源代
- C++primer第五版习题答案及解析
- 八数码问题C++代码
- winhttp 异步c++库
- 学生选课管理系统 C++
- 双目视觉标定棋盘格模板程序
- VC++调用大漠插件
- VC++用MKL产生正态分布随机数、计算样
- 04737 c++程序设计 自考课后练习答案
- C++_与电脑玩21点游戏.zip
- C语言 个人通讯录管理系统
- 浙工大C++通关考模拟题代码
- c++rpg游戏(带存档)
- 数据结构上机题
- Qt/C++ 网站爬虫源码
- 图像处理-读取bmp图像均值滤波-C++
- 图的建立与遍历c++实现邻接矩阵存储
- 骑士周游列国(跳马问题)C++代码实
- VC++ 使用RSA算法防止非法注册机破解软
- VC++开发GIS系统代码陈建春书
- shallow water equation c++ code
- C++实现小型数据库DBMS,具备建表以及
- 模拟的DBMS
- 实现用c++产生高斯噪声
- c++远程控制源代码
- 自己写的远控代码 C++
- C++课程设计公司人员管理系统
- C++程序设计 Y.Daniel Liang著 习题答案
- 纯C++方式生成复杂格式的excel文件(
评论
共有 条评论