C++ log4cpp使用(转)
参考文章:
1、常用C++库(1)日志库 https://blog.csdn.net/qilimi1053620912/article/details/87378707
2、一步步入门log4cpp https://www.cnblogs.com/happyamyhope/p/6872485.html
3、中文文档:便利的开发工具-log4cpp快速使用指南
使用测试:
下载源代码后用cmake生成vs2017工程,然后就可以编译为log4cpp.lib静态库。也可以用自带的msvc工程编译(默认win32,比较麻烦),里面有各种例子和编译为静态库,动态库
我用生成的vs2017工程编译后的静态库在使用时无法使用配置文件方式,可能是编译有问题,暂未找到原因,只能在代码中配置布局,参照上面两位的demo
//FileAppenderExam #include <iostream> #include <log4cpp/Category.hh> #include <log4cpp/Appender.hh> #include <log4cpp/FileAppender.hh> #include <log4cpp/Priority.hh> #include <log4cpp/PatternLayout.hh> #include <log4cpp/RollingFileAppender.hh> using namespace std; // 本示例对同一个category root以不同的布局layout分别输出到两个appender // 注意: // 配置文件的形式在这里无法使用,只能手动在代码里面配置 // log4cpp::PropertyConfigurator::configure(initfilename); int main(int argc, char* argv[]) { log4cpp::PatternLayout* pLayout1 = new log4cpp::PatternLayout();//创建一个Layout; pLayout1->setConversionPattern("%d: %p %c %x: %m%n"); //指定布局格式; // %p:级别,%d:日期,%c:生产者标志,%m%n:内容 log4cpp::PatternLayout* pLayout2 = new log4cpp::PatternLayout(); pLayout2->setConversionPattern("[%p] %d{%Y-%m-%d %H:%M:%S.%l} (%c): %m%n"); // [%p] %d{%H:%M:%S.%l} (%c): %m%n log4cpp::Appender* fileAppender = new log4cpp::FileAppender("fileAppender", "wxb.log");//创建一个Appender; fileAppender->setLayout(pLayout1);//将指定的Layout添加到Appender; log4cpp::RollingFileAppender* rollfileAppender = new log4cpp::RollingFileAppender( "rollfileAppender", "rollwxb.log", 5 * 1024, 1); // 超过5k自动回滚,最大文件数为1 rollfileAppender->setLayout(pLayout2); log4cpp::Category& root = log4cpp::Category::getRoot().getInstance("RootName");//从系统中得到Category的根; root.addAppender(fileAppender);//将Appender添加到Category; root.addAppender(rollfileAppender); root.setPriority(log4cpp::Priority::DEBUG);//设置Category的优先级; //开始记录日志; for (int i = 0; i < 100; i++) { string strError; ostringstream oss; oss << i << ":Root Error Message!"; strError = oss.str(); root.error(strError); } log4cpp::Category::shutdown();//关闭Category; return 0; }
上面的代码分别写入两个日志文件,一个追加,一个回滚。
基本概念和用法了解后就可以参照示例自己封装一下。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探