zoukankan      html  css  js  c++  java
  • 使用logcxx库和boost库构建系统日志的格式化输出

    作者:朱金灿
    来源:http://blog.csdn.net/clever101/


          logcxx库作为一个强大的C++日志系统,在业内得到越来越多的应用。但是logcxx库欠缺一个格式化日志输出的能力,却不能不说这是它的一个比较大的缺陷。当然你可以说借助字符串类的格式化功能,然后把它塞到logcxx库的接口函数里,比如标准C库的snprintf函数,STL的std::ostringstream和MFC的CString的Format接口。snprintf的缺点在于你得先定义一个大缓冲区(不大的话担心装不下日志信息),而且它不是类型安全的;std::ostringstream使用安全,但是还是先得定义ostringstream对象来构造格式化字符串;CString一则是MFC程序专用,二则它不是类型安全的,三则如果把它塞到logcxx库接口里,隐含了一个CString到char*的转换操作。下面我要介绍的方法比上面的方法都要简单和安全,那就是使用boost库的boost::format和boost::lexical_cast。


          logcxx库的使用方法这里我不作赘述,大致是设置一个配置文件,定义输出方式、等级等,大家可以参考这篇文章:log4cxx 用法详解。金庆大侠提出boost::format和logcxx库配合使用(详见参考文献2),我试了一下很好用。不过我发现logcxx和boost::lexical_cast结合同样好用。下面是测试代码:



    编译环境:Win XP + sp3,VS C++ 2005 + sp1


    参考文献:


    1. log4cxx 用法详解


    2. log4cxx配合boost::format ,作者金庆。










  • 相关阅读:
    一、模板的渲染
    十六、ajax上传图片 mvc
    十五、API请求接口-远程服务器返回错误: (400) 错误的请求错误
    九、操作(在结果中搜索+查询该表,单独几个字段查询,通过子查询方式查询)
    一、Vue分页实现
    【2019-10-29】除非你变成你自己
    【2019-10-28】美好在于细节心态
    【2019-10-27】理智是罗盘,感情是大风
    【2019-10-26】日积月累的小惠生者
    【2019-10-25】从错误和失败中获得经验
  • 原文地址:https://www.cnblogs.com/lanzhi/p/6470987.html
Copyright © 2011-2022 走看看