windows下编译log4cxx

环境: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

        

        

你可能感兴趣的:(开源,windows,编译,log4cxx)