zoukankan      html  css  js  c++  java
  • 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;
    
    }

    上面的代码分别写入两个日志文件,一个追加,一个回滚。

    基本概念和用法了解后就可以参照示例自己封装一下。

  • 相关阅读:
    Windows脚本 Bat批处理命令使用教程
    [Jobdu] 题目1420:Jobdu MM分水果
    排序算法的时间复杂度和空间复杂度
    (转) CS的顶级会议和期刊
    句柄是什么?1
    批处理for命令详解(转)
    cmd批处理常用符号详解
    【转帖】请问两个大于号>>代表什么意思?
    今天玩angry birds
    C/C++数组名与指针区别深入探索
  • 原文地址:https://www.cnblogs.com/jixiaohua/p/12164698.html
Copyright © 2011-2022 走看看