环境:win7,vs2008/vs2010
1.介绍
log4cxx是开放源代码项目Apache Logging Service的子项目之一,是Java社区著名的log4j的c++移植版,用于为C++程序提供日志功能,以便开发者对目标程序进行调试和审计。有关log4cxx的更多信息可以从Apache Loggin Service的网站http://logging.apache.org获得。当前的最新版本为0.10.0,本文内容及示例代码都是基于此版本。
2.获取软件包
log4cxx依赖apr、apr-util这两个库,apr-util有个可选依赖库apr-iconv,可以通过修改APU_HAVE_APR_ICONV宏定义移除对apr-iconv的引用。这里编译的用到的源码主页及源码地址地址:
log4cxx-0.11.0
https://github.com/apache/logging-log4cxx
https://github.com/apache/logging-log4cxx/archive/refs/tags/v0.11.0.zip
apr-1.4.2
https://apr.apache.org/download.cgi
https://archive.apache.org/dist/apr/apr-1.4.2-win32-src.zip
apr-util-1.3.9
https://archive.apache.org/dist/apr/apr-util-1.3.9-win32-src.zip
apr-iconv-1.2.1
https://archive.apache.org/dist/apr/apr-iconv-1.2.1-win32-src-r2.zip
下载完把他们放到同一个目录,解压后将文件夹名中的版本号去掉,即
C:/work
|_ apr
|_ apr-iconv
|_ apr-util
|_ log4cxx(名称任意)
3.编译
3.1、用vs打开apr/apr.dsw,全部编译生成,libapr编译成功
3.2、用vs打开apr-iconv/libapriconv.dsp,全部编译生成
3.3、用vs打开apr-util/aprutil.dsw,全部编译生成,确保libaprutil编译成功。这里可以修改一个宏定义APU_HAVE_APR_ICONV,在apr-util\include\apu.hw中,当APU_HAVE_APR_ICONV改为0时,不需要依赖apr-iconv库,当APU_HAVE_APR_ICONV改为1时,需要依赖并提前编译apr-iconv库
3.4、 log4cxx-0.11.0有人给写了CMakeLists.txt,那用cmake就比较方便了。可以先装一个cmake,然后在cmd里进入log4cxx-0.11.0目录,依次输入
mkdir build
cd build
cmake ../ -G "Visual Studio 9 2008" -DAPR_INCLUDE_DIR="E:\code\apr\include" -DAPR_LIBRARIES="E:\code\apr\Debug\libapr-1.lib" -DAPR_UTIL_INCLUDE_DIR="E:\code\apr-util-1.3.9\include" -DAPR_UTIL_LIBRARIES="E:\code\apr-util-1.3.9\Debug\libaprutil-1.lib" -DBUILD_TESTING=OFF
生成解决方案的sln文件后,用vs直接编译生成就可以了,也比较简单。
4.测试代码
a.新建工程
b.设置属性,然后在C++选项卡中添加附加包含目录,注意该目录为../ apache-log4cxx-0.10.0\src\main\include ($(ProjectDir)\include)
c.在属性的链接器输入选项卡的”附加依赖项”中添加”log4cxx.lib”将log4cxx.lib和log4cxx.dll两个文件拷贝到工程目录下
d
#include "stdafx.h"
#include "log4cxx/logger.h"
int _tmain(int argc, _TCHAR* argv[])
{
log4cxx::LoggerPtr logger(log4cxx::Logger::getLogger("MyApp"));
LOG4CXX_INFO(logger, "hello, world");
system("pause");
return 0;
}
参考:
http://www.nndssk.com/rjwt/155619bBTCrV.html
https://blog.csdn.net/u010855021/article/details/75452989
https://blog.csdn.net/tusong86/article/details/112688712