log4cpp配置文件log4j.properties log4cpp.properties

cpp 复制代码
log4cpp.rootCategory=DEBUG, Console
log4cpp.category.Debug=DEBUG, Debug
log4cpp.category.Info=DEBUG, Info
log4cpp.category.Data=DEBUG, Data

#ConsoleAppender target
log4cpp.appender.Console=ConsoleAppender
log4cpp.appender.Console.layout=PatternLayout
log4cpp.appender.Console.layout.ConversionPattern=[%d{%Y-%m-%d %H:%M:%S.%l}] %m%n

#FileAppender
#RollingFileAppender fileName maxFileSize=10*1024*1024 maxBackupIndex append  layout  maxBackupIndex 日志文件备份数量
log4cpp.appender.Debug=RollingFileAppender
log4cpp.appender.Debug.name=Debug
log4cpp.appender.Debug.fileName=Log
log4cpp.appender.Debug.maxFileSize=10485760
log4cpp.appender.Debug.maxBackupIndex=1
log4cpp.appender.Debug.append=false
log4cpp.appender.Debug.layout=PatternLayout
log4cpp.appender.Debug.layout.ConversionPattern=[%d{%Y-%m-%d %H:%M:%S.%l}] %m%n

log4cpp.appender.Info=DailyRollingFileAppender
log4cpp.appender.Info.fileName=Info
log4cpp.appender.Info.maxDaysKeep=1
log4cpp.appender.Info.append=false
log4cpp.appender.Info.layout=PatternLayout
log4cpp.appender.Info.layout.ConversionPattern=[%d{%Y-%m-%d %H:%M:%S.%l}] %m%n

#DailyRollingFileAppender fileName maxDaysKeep=30 append=true mode=00644 maxDaysKeep=1100(三年) 100(三月) 最大保留天数 超过的会被删除
log4cpp.appender.Data=DailyRollingFileAppender
log4cpp.appender.Data.name=Data
log4cpp.appender.Data.fileName=Data
log4cpp.appender.Data.backupPattern=%Y-%m-%d
log4cpp.appender.Data.DatePattern=%Y-%m-%d
log4cpp.appender.Data.maxDaysKeep=1
log4cpp.appender.Data.append=false
log4cpp.appender.Data.layout=PatternLayout
log4cpp.appender.Data.layout.ConversionPattern=[%d{%Y-%m-%d %H:%M:%S.%l}] %m%n

使用代码

cpp 复制代码
#ifndef LOGFACTORY_H
#define LOGFACTORY_H
class LogFactory
{
public:
    LogFactory();
    static int Init(const char* file);
    static int Exit();
    static int print_s(const char* _Format, ...);
    static int print(const char* file, const char* _Format, ...);

};
#define LOG_DEBUE1(NAME, format, ...) LogFactory::print(NAME,format,##__VA_ARGS__);

#define LOG_DEBUG2(NAME, format, ...) LogFactory::print(NAME,"[%s %s %d]"##format,__FILE__,__FUNCTION__, __LINE__,##__VA_ARGS__);

#endif // LOGFACTORY_H




#include "LogFactory.h"

#include <log4cpp/Category.hh>
#include <log4cpp/PropertyConfigurator.hh>
#include <log4cpp/OstreamAppender.hh>
#include <log4cpp/DailyRollingFileAppender.hh>
#include <log4cpp/SimpleLayout.hh>
LogFactory::LogFactory()
{

}

int LogFactory::Init(const char *file)
{
    int result = 0;
    log4cpp::PropertyConfigurator::configure(file);
    return result;
}

int LogFactory::Exit()
{
    int result = 0;
    log4cpp::Category::shutdown();
    return result;
}

int LogFactory::print_s(const char* const _Format, ...)
{
    int _Result;
    va_list _ArgList;
    const int _BufferCount = 1000;
    char buffer[_BufferCount] = {0};
    va_start(_ArgList, _Format);
    _Result = vsnprintf(buffer, _BufferCount, _Format, _ArgList); //_Result = _vfprintf_l(stdout, _Format, NULL, _ArgList);
    va_end(_ArgList);
    log4cpp::Category::getInstance("").debug(buffer);
    std::cout<<std::endl;
    return _Result;
}

int LogFactory::print(const char *file, const char *_Format, ...)
{
    int _Result;
    va_list _ArgList;
    const int _BufferCount = 1000;
    char buffer[_BufferCount] = {0};
    va_start(_ArgList, _Format);
    _Result = vsnprintf(buffer, _BufferCount, _Format, _ArgList); //_Result = _vfprintf_l(stdout, _Format, NULL, _ArgList);
    va_end(_ArgList);
    log4cpp::Category::getInstance(file).debug(buffer);
    std::cout<<std::endl;
    return _Result;
}
cpp 复制代码
#include <QCoreApplication>
#include "LogFactory.h"

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    std::string appdir = QCoreApplication::applicationDirPath().toStdString().append("/log4j.properties");//应用程序路径
    LogFactory::Init(appdir.data());
    LOG_DEBUE1("Info", "log4cpp Info");
    LOG_DEBUE1("Data", "log4cpp Data");
    LogFactory::Exit();
    return 0;
}
相关推荐
清水白石0082 分钟前
从打印对象到高质量调试:彻底理解 Python 中 `__repr__` 和 `__str__` 的区别
开发语言·python
枕星而眠8 分钟前
C++ 面向对象核心机制深度解析:多态性、虚函数、虚继承与 final 类
运维·开发语言·c++·后端
智者知已应修善业33 分钟前
【51单片机8个LED,已经使用了D1D2,怎么样在不动D1D2的前提下实现D6~D8的流水灯】2024-1-19
c++·经验分享·笔记·算法·51单片机
Evand J34 分钟前
【MATLAB例程】自适应渐消扩展卡尔曼滤波(AFEKF)三维雷达目标跟踪|效果已调优,附下载链接和运行结果,代码直接运行即可
开发语言·算法·matlab·目标跟踪·卡尔曼滤波·自适应滤波·代码定制
坚果派·白晓明35 分钟前
鸿蒙PC适配实战:simdjson 三方库移植攻略与 AtomCode Skills 提效之道
c++·harmonyos·三方库·skills·atomcode·c/c++三方库·c/c++三方库适配
爱装代码的小瓶子35 分钟前
3. 设计buffer模块
linux·服务器·开发语言·c++·php
郝学胜-神的一滴35 分钟前
Qt 高级开发 027: QTabWidget自定义样式表美化实战
开发语言·c++·qt·程序人生·软件构建·用户界面
keykey6.36 分钟前
迁移学习实战:用预训练模型做图像分类
开发语言·人工智能·深度学习·机器学习
双河子思37 分钟前
《代码整洁之道》——读书笔记(持续更新)
开发语言·c++·c#
川冰ICE37 分钟前
JavaScript实战②|电商网站交互效果,轮播图与购物车
开发语言·javascript·交互