一、下载

  http://sourceforge.net/projects/log4qt/develop

二、Log4Qt介绍

  Log4Qt 是Apache Log4J 的Qt移植版,所以看Log4J的资料应该是最直接有效的(因为Log4Qt的直接资料太少了)。

  Log4Qt主要是用来记录日志(有助于程序调试)。有3个主要的组件:

  Logger
提供日志记录服务,可以有多个Logger存在,每个有它们自己的名字。Logger间存在隶属关系,有一个Logger称为根Logger。
  Appender
用来指明将日志记录到什么地方:比如,控制台、文件、数据库,等等
  Layout
控制日志的输出格式,可以类比一下C中的printf哈。

三、使用Log4Qt

  由于程序中包含很多动态库,而几乎每个动态库都需要使用log功能,此时直接包含Log4Qt的源码或者使用静态库都不是太好的注意。所以:使用动态库

  其实只要写好工程文件,使用动态库也很简单:

  3.1 创建Qt工程,命名为libLog4Qt

  3.2 在项目根目录下新建文件夹3rdparty,并把下载的源代码中的放置在里面。

  3.3 编辑libLog4Qt.pro内容如下:

  目的:构建一个动态库

TEMPLATE = lib
CONFIG += log4qt-buildlib
QT += core xml network include(liblog4qt.pri)
TARGET = $$LIBLOG4QT_NAME
DESTDIR = $$PROJECT_LIBDIR
win32{
DLLDESTDIR = $$PROJECT_BINDIR
QMAKE_DISTCLEAN += $$PROJECT_BINDIR/$${LIBLOG4QT_NAME}.dll
}
CONFIG += debug_and_release build_all LOG4QT_VERSION_MAJOR =
LOG4QT_VERSION_MINOR =
LOG4QT_VERSION_RELEASE = LOG4QT_VERSION = '\\"$${LOG4QT_VERSION_MAJOR}.$${LOG4QT_VERSION_MINOR}.$${LOG4QT_VERSION_RELEASE}\\"'
DEFINES += LOG4QT_VERSION_STR=\"$${LOG4QT_VERSION}\"
DEFINES += LOG4QT_VERSION=$${LOG4QT_VERSION} VERSION = 1.0. DEPENDPATH += src src/helpers src/spisrc/ varia
INCLUDEPATH += src src/helpers src/spi src/varia

  3.4 在以上创建的工程根目录下创建文档 libLog4Qt.pri

  编辑 libLog4Qt.pri如下:

  一开始定义几个变量:

  • 我们下载的 log4qt 所放置的目录
  • 我们的库文件准备放置到的路径(所有的动态库都需要这个,放置到单独一个common.pri中更好)
  • 库文件的名字(使用了qtLibraryTarget,这样在windows下debug和release自动拥有不同的名字,而且对我们是透明的,因为我们只在这一个文件内指定库文件的名字。)
LOG4QTSRCPATH = $$PWD/3rdparty/log4qt/src/log4qt
PROJECT_LIBDIR = $$PWD/lib
PROJECT_BINDIR = $$PWD/bin TEMPLATE += fakelib
LIBLOG4QT_NAME = $$qtLibraryTarget(hlog4qt)
TEMPLATE -= fakelib INCLUDEPATH += $$LOG4QTSRCPATH
DEPENDPATH += $$LOG4QTSRCPATH !log4qt-buildlib{
DEFINES += LOG4QT_IMPORTS
LIBS += -L$$PROJECT_LIBDIR -l$$LIBLOG4QT_NAME
}else{
DEFINES += LOG4QT_EXPORTS
INCLUDEPATH += -L$$PROJECT_LIBDIR $$LOG4QTSRCPATH/helpers \
$$LOG4QTSRCPATH/spi \
$$LOG4QTSRCPATH/varia
DEPENDPATH += $$LOG4QTSRCPATH/helpers \
$$LOG4QTSRCPATH/spi \
$$LOG4QTSRCPATH/varia
include($$LOG4QTSRCPATH/Log4Qt.pri)
}

创建libLog4Qt.pro

用来构建动态库

可以单独存在,也可以被上级的pro文件所包含(通过subdir)

创建libLog4Qt.pri

用来构建和使用动态库

任何需要使用log工程的pro文件,只需要include该文件即可

  3.5 编译项目,我们可以在lib目录下看到四个文件:

  libhlog4qt.so   libhlog4qt.so.1     libhlog4qt.so.1.0      libhlog4qt.so.1.0.0

  这表明我们已经成功构建来关于Log4Qt的动态库了。

  下面,我们就可以使用上面生成的动态库。

  3.6 我们在新项目中使用以上动态库需要做的事情:

  在.pro中加入:

LIBS += -L$$PWD/3rdParty/lib/ -lhlog4qt

INCLUDEPATH += $$PWD/3rdParty
DEPENDPATH += $$PWD/3rdParty

  并在使用前包含头文件和使用log:

  

#include "logger.h"
#include "basicconfigurator.h" int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
Log4Qt::BasicConfigurator::configure();
Log4Qt::Logger * log = Log4Qt::Logger::rootLogger();
log->debug("Hello DbZhang800!");
log->info("Hello Qt!");
log->warn("Hello 1+1=2");
return ;
}

至此,我们已可以成功使用Log4Qt了。

最新文章

  1. python 旋转数组
  2. webstorm+react+webpack-demo
  3. Web 数据存储总结
  4. php格式化金额函数分享
  5. jquery中append跟prepend的用法
  6. alt属性和title属性差异---终于分清楚了!
  7. OnItemSelectedListener事件与二级联动
  8. Apache common包应用集合
  9. 【原创】Android 对话框的使用
  10. APCS
  11. ajax提交表单序列化(serialize())数据
  12. Android平均分布的布局图像的下一行
  13. JAVA环境配置---------jdk安装路径中存在空格的问题
  14. 3、XCode: 如何添加自定义代码片段
  15. mobile开发中常用的css
  16. Promise原理讲解 && 实现一个Promise对象 (遵循Promise/A+规范)
  17. Confluence 6 布局高级自定义
  18. 从0x7fffffff+1开始的数学期望
  19. 嵌入式开发之hisilicon---hi3536 处理器简介
  20. Spring Boot—21Actuator--监控

热门文章

  1. 第一个androidAPP项目总结—数据请求
  2. 【转】Mysql三种备份详解
  3. linux 第二天
  4. 不用修改nginx的高并发合并回源架构
  5. 流Stream个人学习理解
  6. Python3 如何优雅地使用正则表达式(详解四)
  7. jquery编写插件
  8. oracle 数据库连接的四种方式
  9. JS--图片轮播效果
  10. ora-01445 无法从不带保留关键字的表的联接视图中选择 ROWID 或采样