log4cplus使用

下载源码

wget https://phoenixnap.dl.sourceforge.net/project/log4cplus/log4cplus-stable/2.1.2/log4cplus-2.1.2.tar.gz

如下图所示即为安装完成

解压&安装

执行下述命令,解压下载的源码,并且进入解压后的目录

tar -xzvf log4cplus-2.1.2.tar.gz
cd log4cplus-2.1.2

配置

cmake .. \
    -DCMAKE_INSTALL_PREFIX=/usr/local \
    -DLOG4CPLUS_BUILD_LOGGINGSERVER=ON \
    -DLOG4CPLUS_BUILD_TESTS=ON \
    -DLOG4CPLUS_ENABLE_DEBUG=ON \
    -DLOG4CPLUS_MULTITHREADED=ON \
    -DLOG4CPLUS_BUILD_STATIC_LIBS=OFF \
    -DLOG4CPLUS_BUILD_SHARED_LIBS=ON
  • cmake后面的“..”是指定上一级目录,因为当前目录是在新建的build目录下
  • -DCMAKE_INSTALL_PREFIX:指定安装路径,默认是/usr/local
  • -DLOG4CPLUS_BUILD_LOGGINGSERVER:是否构建日志服务器(可选)。
  • -DLOG4CPLUS_BUILD_TESTS:是否构建测试程序(可选)。
  • -DLOG4CPLUS_ENABLE_DEBUG:是否启用调试信息。
  • -DLOG4CPLUS_MULTITHREADED:是否启用多线程支持(推荐开启)。
  • -DLOG4CPLUS_BUILD_STATIC_LIBS:是否构建静态库。
  • -DLOG4CPLUS_BUILD_SHARED_LIBS:是否构建动态库。

编译

执行下述命令进行编译

make -j$(nproc)

出现下图所示即代表编译成功

安装

执行下述命令进行安装

make install

出现下图所示即代表安装成功,在前面配置安装的路径(/usr/local)下能够找到对应的头文件和库文件,至此,后续开发时即可使用log4cplus了

验证

创建一个项目然后引用安装的log4cplus

引入库文件和头文件

在cmakelists中做如下编辑即可

cmake_minimum_required(VERSION 3.27)
project(log4cplusExample)

set(CMAKE_CXX_STANDARD 20)

add_executable(log4cplusExample main.cpp)
# 指定可执行文件的输出路径
set_target_properties(log4cplusExample PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)

# 指定log4cplus头文件路径
target_include_directories(log4cplusExample PRIVATE /usr/local/include/log4cplus)

# 指定log4cplus库文件路径
target_link_directories(log4cplusExample PRIVATE /usr/local/lib)

# 链接log4cplus库
target_link_libraries(log4cplusExample log4cplus)
设置log4cplus配置文件
log4cplus.rootLogger=DEBUG, stdout, file

log4cplus.appender.stdout=log4cplus::ConsoleAppender
log4cplus.appender.stdout.layout=log4cplus::PatternLayout
log4cplus.appender.stdout.layout.ConversionPattern=%d{%m/%d %H:%M:%S} %-5p %c{2} - %m%n

log4cplus.appender.file=log4cplus::FileAppender
log4cplus.appender.file.File=app.log
log4cplus.appender.file.layout=log4cplus::PatternLayout
log4cplus.appender.file.layout.ConversionPattern=%d{%m/%d %H:%M:%S} %-5p %c{2} - %m%n
测试执行

注意:配置文件的路径和可执行文件的路径一定要对应上,避免找不到配置文件

#include "log4cplus/log4cplus.h"

int main() {

    // 加载.properties格式的配置文件
    log4cplus::PropertyConfigurator config("/mnt/d/clion_project/log4cplusExample/config/log4cplus.properties");
    config.configure();

    // 记录一条日志
    LOG4CPLUS_INFO(log4cplus::Logger::getRoot(), "Hello, log4cplus!");

    LOG4CPLUS_WARN(log4cplus::Logger::getRoot(), "Hello, log4cplus!");
    
    LOG4CPLUS_DEBUG(log4cplus::Logger::getRoot(), "Hello, log4cplus!");
    return 0;
}

执行结果如下图所示

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值