log4cpp封装成独立的类(单例模式)

一、编译安装

二、封装使用

头文件Logger.h:

cpp 复制代码
#ifndef DISTRIBUTED_LOGGER_H_
#define DISTRIBUTED_LOGGER_H_

#include <string>
#include <log4cpp/Category.hh>


class Logger{
public:
    bool init(const std::string& log_conf_file);

    static Logger* instance(){//返回单例------全局唯一对象
        return &instance_;
    }
    log4cpp::Category* get_handle(){
        return category_;
    }
    
protected:
    static Logger instance_;
    log4cpp::Category* category_;
};

#define LOG_INFO Logger::instance()->get_handle()->info
#define LOG_DEBUG Logger::instance()->get_handle()->debug
#define LOG_ERROR Logger::instance()->get_handle()->error
#define LOG_WARN Logger::instance()->get_handle()->warn

#endif

实现类Logger.cpp:

cpp 复制代码
#include "Logger.h"

#include <iostream>
#include <log4cpp/Category.hh>
#include <log4cpp/FileAppender.hh>
#include <log4cpp/PatternLayout.hh>
#include <log4cpp/OstreamAppender.hh>
#include <log4cpp/PropertyConfigurator.hh>

Logger Logger::instance_;

bool Logger::init(const std::string& log_conf_file){
    try{
        log4cpp::PropertyConfigurator::configure(log_conf_file);

    }catch(log4cpp::ConfigureFailure& f){
        std::cerr << " load log config file " << log_conf_file.c_str() << " failed with result : " << f.what()<< std::endl;
        return false;
    }
    category_ = &log4cpp::Category::getRoot();
    return true;
}
相关推荐
和道一文字yyds15 小时前
16天 - 单例模式有哪几种实现?如何保证线程安全?什么是策略模式?一般用在什么场景?什么是模板方法模式?一般用在什么场景?
安全·单例模式·策略模式
爱吃烤鸡翅的酸菜鱼16 小时前
Java【多线程】(3)单例模式与线程安全
java·开发语言·安全·单例模式·intellij idea
yyueshen2 天前
单例模式,有必要用volatile么?
java·单例模式·设计模式
周努力.2 天前
设计模式之单例模式
单例模式·设计模式
倒霉男孩3 天前
单例设计模式---懒汉式--线程安全和不安全、枚举类
安全·单例模式·设计模式
帅的飞起来4 天前
设计模式--单例模式
java·单例模式·设计模式
Amazing_snack4 天前
设计模式--单例模式(Singleton)【C++】
单例模式·设计模式
isolusion4 天前
单例模式:确保一个类只有一个实例
单例模式
牵牛老人4 天前
C++设计模式中的单例模式:从原理、应用、实践指南与常见问题和解决方案深度解析
c++·单例模式·设计模式
zzlyyds4 天前
单例模式的五种实现方式
java·开发语言·单例模式·设计模式