前言

项目实现过程中,需要检查、查找或者调试程序bug等,此时程序日志则较为清晰地展现代码的运行过程。目前接触到的方法有打印消息到控制台,将重要信息输出到某个文件比如txt文件,或者直接使用日志库。

为了方便移植,采用日志库的方式,目前主流的日志库有log4j、glog、log4cpp等等,本文采用log4cpp日志库。

实现步骤

1.下载源代码包;

2.编译链接;

3.配置环境变量;

4.简单实例;

实现环境

系统环境:win7 64bit

开发环境:vs2013

软件版本:log4cpp-1.1.2.tar.gz

实现过程

1.下载源码包;

下载地址(本文下载链接):

https://sourceforge.net/projects/log4cpp/

下载完成之后解压即可;

log4cpp主页:

http://log4cpp.sourceforge.net/

源码包文件如下图所示:

 2.编译链接;

将文件夹中的msvc10文件夹复制到当前目录下,并将文件夹重命名为msvc11,同时将文件夹内的解决方案改为msvc11.sln;

该解决方案包含多个工程项目,有log4cpp静态库、log4cppLIB动态库以及一项相应的demo工程。本文使用的是log4cppLIB静态库,分别在release和debug模式下进行编译链接生成相应的库文件。

为方便,将需要的头文件和库文件复制到某一个新建的文件夹中(C:\Program Files\log4cpp)。

1)库文件:将log4cppLIB生成的库文件log4cppD.lib(Debug模式)、log4cppLIB.lib(Release模式) 复制到 C:\Program Files\log4cpp\lib文件夹;

2)头文件:将该库用到的库文件.\log4cpp\include文件夹复制到C:\Program Files\log4cpp文件夹中;

工程文件如下图所示:

注意:

3.配置环境及属性;

1)环境变量;

为了代码的可在不同的电脑进行编译,避免引用问题,建议使用环境变量对文件引用路径进行配置。

> 打开系统的环境变量中在用户变量中添加:

变量名:LOG4CPP_ROOT

变量值:C:\Program Files\log4cpp

> 在系统环境变量的系统变量path值中添加

变量值:;%LOG4CPP_ROOT%\lib

注意:重启电脑配置的环境变量生效。

2)VS项目属性;

分别配置VS项目Debug和Release模式的属性;

(1)打开项目属性页面,VC++目录选项常规下的包含目录,新建添加为$(LOG4CPP_ROOT)\include;

(2)打开项目属性页面,VC++目录选项常规下的库目录,新建添加为$(LOG4CPP_ROOT)\lib;

(3)打开项目属性页面,链接器输入选项下的附加依赖项,添加log4cppD.lib(Debug模式);或者log4cppLIB.lib(Release模式);

注意:

4.简单实例;

  1. //FileAppenderExam:
  2. #include <iostream>
  3. #include <log4cpp/Category.hh>
  4. #include <log4cpp/Appender.hh>
  5. #include <log4cpp/FileAppender.hh>
  6. #include <log4cpp/Priority.hh>
  7. #include <log4cpp/PatternLayout.hh>
  8. #include <log4cpp/RollingFileAppender.hh>
  9. using namespace std;
  10.  
  11. int main(int argc, char* argv[])
  12. {
  13. log4cpp::PatternLayout* pLayout1 = new log4cpp::PatternLayout();//创建一个Layout;
  14. pLayout1->setConversionPattern("%d: %p %c %x: %m%n");//指定布局格式;
  15.  
  16. log4cpp::PatternLayout* pLayout2 = new log4cpp::PatternLayout();
  17. pLayout2->setConversionPattern("%d: %p %c %x: %m%n");
  18.  
  19. log4cpp::Appender* fileAppender = new log4cpp::FileAppender("fileAppender", "wxb.log");//创建一个Appender;
  20. fileAppender->setLayout(pLayout1);//将指定的Layout添加到Appender;
  21.  
  22. log4cpp::RollingFileAppender* rollfileAppender = new log4cpp::RollingFileAppender(
  23. "rollfileAppender", "rollwxb.log", * , );
  24. rollfileAppender->setLayout(pLayout2);
  25.  
  26. log4cpp::Category& root = log4cpp::Category::getRoot().getInstance("RootName");//从系统中得到Category的根;
  27. root.addAppender(fileAppender);//将Appender添加到Category;
  28. root.addAppender(rollfileAppender);
  29. root.setPriority(log4cpp::Priority::DEBUG);//设置Category的优先级;
  30.  
  31. //开始记录日志;
  32. for (int i = ; i < ; i++)
  33. {
  34. string strError;
  35. ostringstream oss;
  36. oss << i << ":Root Error Message!";
  37. strError = oss.str();
  38. root.error(strError);
  39. }
  40.  
  41. log4cpp::Category::shutdown();//关闭Category;
  42. return ;
  43.  
  44. }

参考

1.log4cpp的使用:http://blog.csdn.net/xinhuo11/article/details/11061137

2.基于LGPL开源项目 Log4cpp安装与使用:

http://tech.it168.com/a2011/0408/1175/000001175907_all.shtml

3.http://www.voidcn.com/blog/sf2gis2/article/p-5704173.html

4.https://sourceforge.net/projects/log4cpp/files/

5.http://www.cnblogs.com/sanghg/p/4203153.html

6.https://sourceforge.net/projects/log4cpp/

7.log4cpp主页:http://log4cpp.sourceforge.net/

做自己该做的事情,做自己喜欢做的事情,安静做一枚有思想的技术媛。

一步步入门log4cpp的更多相关文章

  1. 一步步入门编写PHP扩展

    1.写在最前 随着互联网飞速发展,lamp架构的流行,php支持的扩展也越来越多,这样直接促进了php的发展. 但是php也有脚本语言不可避免的问题,性能比例如C等编译型语言相差甚多,所以在考虑性能问 ...

  2. C++ log4cpp使用(转)

    参考文章: 1.常用C++库(1)日志库 https://blog.csdn.net/qilimi1053620912/article/details/87378707 2.一步步入门log4cpp  ...

  3. 自学MVC看这里——全网最全ASP.NET MVC 教程汇总

    MVC架构已深得人心,微软也不甘落后,推出了Asp.net MVC.小编特意整理博客园乃至整个网络最具价值的MVC技术原创文章,为想要学习ASP.NET MVC技术的学习者提供一个整合学习入口.本文从 ...

  4. PHP 扩展开发(将自己的一些代码封装成PHP扩展函数)

    今天时间不多,先给个地址,能搜到我这篇blog的朋友先看看我最近在看的一些文章.资料吧: 我的环境是 lnmp1.1 的 (LNMP一键安装包),所以要进行PHP扩展开发首先应该对环境配置和shell ...

  5. 百度前端技术学院(IFE)2016春季学期总结

    今天(5月16日)作为第八个提交者提交了任务五十:RIA微型问卷管理平台 这样一个综合性的大任务,宣告我的IFE春季学期课程学习顺利完成.其实任务五十并不复杂,现在再让我来做,可能一周不到就写出来了, ...

  6. OO第二单元单元总结

    总述 OO的第二单元主题是电梯调度,与第一单元注重对数据的输入输出的处理.性能的优化不同,第二单元的重心更多的是在线程安全与线程通信上.这此次单元实验之前,我并未对线程有过了解,更谈不上“使用经验”, ...

  7. PHP -- 简单表单提交

    网上看博文,一步步入门~~ 简单表单,简单提交 @_@!! <?php //php代码部分开始 echo "<html>"; echo "<hea ...

  8. 自学MVC看这里——全网最全ASP.NET MVC 教程汇总【转】

    自学MVC看这里——全网最全ASP.NET MVC 教程汇总 http://www.cnblogs.com/powertoolsteam/archive/2015/08/13/4667892.html ...

  9. Arthas 开源一周年,GitHub Star 16 K ,我们一直在坚持什么?

    缘起 最近看到一个很流行的标题,<开源XX年,star XXX,我是如何坚持的>.看到这样的标题,忽然发觉 Arthas 从 2018 年 9 月开源以来,刚好一年了,正好在这个秋高气爽的 ...

随机推荐

  1. ros 查找包路径

    rospack find 包名

  2. Springboot mybatis generate 自动生成实体类和Mapper

    https://github.com/JasmineQian/SpringDemo_2019/tree/master/mybatis Springboot让java开发变得方便,Springboot中 ...

  3. VC6_导入lib库

    http://www.cnblogs.com/webcyz/p/3525166.html 2. 导入lib库.导入的方法很多方法1) 直接用project>add to project>f ...

  4. [ios]ios tts的使用

    参考:http://www.tekuba.net/program/327/ http://blog.sina.com.cn/s/blog_923fdd9b0101flx3.html iOS平台由于本身 ...

  5. Python string常用函数

    2017-07-03 23:26:08 1..replace(self, old, new, count=-1) replace()函数将旧字符串替换为新字符串,最后一个参数count为可选项,表示替 ...

  6. .net开发中,C# DateTime.Now 取出的时间含有星期解决办法

    1.开始→运行→输入regedit,打开注册表编辑器,找到HKEY_USERS. 2.ctrl+f 查找sShortDate(多查询几次,将所有的都查出来). 3.在右边的窗口中找到sDate项,将其 ...

  7. C#复制文件

    string pLocalFilePath ="";//要复制的文件路径 string pSaveFilePath ="";//指定存储的路径 if (File ...

  8. 『cs231n』无监督学习

    经典无监督学习 聚类 K均值 PCA主成分分析 等 深度学习下的无监督学习 自编码器 传统的基于特征学习的自编码器 变种的生成式自编码器 Gen网络(对抗式生成网络) 传统自编码器 原理 类似于一个自 ...

  9. Thrift0.11.0基于Intellij IDEA的简单的例子

    前言 目前流行的服务调用方式有很多种,例如基于 SOAP 消息格式的 Web Service,基于 JSON 消息格式的 RESTful 服务等.其中所用到的数据传输方式包括 XML,JSON 等,然 ...

  10. vuecli3 引入script 针对没有cmd amd require等方式的js

    最近做高德开发,需要引入高德的js,但是 说实话 高德官方的文档不知道大佬们有没有看懂,反正我是没看懂,写的都什么鬼?我怎么引都引入不了,迫不得已想到了如下方法: 一.准备一个能够在页面中插入js的方 ...