首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >未写入的boost日志文件

未写入的boost日志文件
EN

Stack Overflow用户
提问于 2013-08-03 16:09:06
回答 1查看 8.7K关注 0票数 17

我已经为boost日志挣扎了一段时间--我得到了他们编写日志文件(file.cpp)的简单示例。但是,当我试图将代码复制到“Logger”类时,我无法让它写入日志文件。我可以看到创建了default.log文件,但是文件中没有任何内容。

我在使用debian 7 64位。所有编译精细的行都是:

代码语言:javascript
复制
g++ -o build/Logger.o -c -std=c++11 -Wall -g -O0 -DBOOST_LOG_DYN_LINK -DDEBUG src/Logger.cpp
g++ -o build/logtest build/Logger.o -lboost_log -lboost_log_setup -lboost_date_time -lboost_thread -lboost_wave -lboost_regex -lboost_program_options

这是我的密码:

Logger.cpp

代码语言:javascript
复制
/*
 * Logger.cpp
 *
 *  Created on: 2011-01-17
 *      Author: jarrett
 */

#include "Logger.h"

namespace logging = boost::log;
namespace sinks = boost::log::sinks;
namespace src = boost::log::sources;
namespace expr = boost::log::expressions;
namespace attrs = boost::log::attributes;
namespace keywords = boost::log::keywords;

namespace dhlogging {

Logger::Logger(std::string fileName)
{
    initialize(fileName);
}

Logger::Logger(Logger const&)
{
}

Logger::~Logger()
{

}

Logger* Logger::logger_ = nullptr;
Logger* Logger::getInstance(std::string logFile)
{
    if ( Logger::logger_ == nullptr ) {
        logging::add_file_log( logFile );

        logging::core::get()->set_filter
        (
            logging::trivial::severity >= logging::trivial::info
        );

        logging::add_common_attributes();
        Logger::logger_ = new Logger(logFile);
    }

    return Logger::logger_;
}

void Logger::initialize(std::string fileName)
{   
    BOOST_LOG(log_) << "Hello, World!";
    BOOST_LOG_SEV(log_, info) << "Hello, World2!";
}

void Logger::logInfo(std::string message)
{
    BOOST_LOG_SEV(log_, info) << message;
}

void Logger::logDebug(std::string message)
{
    BOOST_LOG_SEV(log_, debug) << message;
}

void Logger::logWarn(std::string message)
{
    BOOST_LOG_SEV(log_, warning) << message;
}

void Logger::logError(std::string message)
{
    BOOST_LOG_SEV(log_, error) << message;
}

void Logger::logFatal(std::string message)
{
    BOOST_LOG_SEV(log_, fatal) << message;
}

}

int main(int, char*[])
{
    logging::add_common_attributes();

    using namespace logging::trivial;

    dhlogging::Logger::getInstance()->logInfo("himom");

    return 0;
}

Logger.h

代码语言:javascript
复制
/*
 * Logger.h
 *
 *  Created on: 2011-01-17
 *      Author: jarrett
 */

#ifndef LOGGER_H_
#define LOGGER_H_

#include <map>
#include <boost/log/core.hpp>
#include <boost/log/trivial.hpp>
#include <boost/log/expressions.hpp>
#include <boost/log/sinks/text_file_backend.hpp>
#include <boost/log/utility/setup/file.hpp>
#include <boost/log/utility/setup/common_attributes.hpp>
#include <boost/log/sources/severity_logger.hpp>
#include <boost/log/sources/record_ostream.hpp>

namespace logging = boost::log;
namespace sinks = boost::log::sinks;
namespace src = boost::log::sources;
namespace expr = boost::log::expressions;
namespace attrs = boost::log::attributes;
namespace keywords = boost::log::keywords;

using namespace logging::trivial;

namespace dhlogging {
class Logger {

public:
    static Logger* getInstance(std::string logFile = "default.log");

    void logInfo(std::string message);
    void logDebug(std::string message);
    void logWarn(std::string message);
    void logError(std::string message);
    void logFatal(std::string message);


private:
    Logger(std::string fileName);
    Logger(Logger const&);
    Logger& operator=(Logger const&);
    virtual ~Logger();

    void initialize(std::string fileName);

    src::severity_logger< severity_level > log_;

    static Logger* logger_; // singleton instance
};
}
#endif /* LOGGER_H_ */
EN

Stack Overflow用户

回答已采纳

发布于 2013-08-03 18:36:29

创建文件日志时需要此属性。

代码语言:javascript
复制
keywords::auto_flush = true 

这样,日志入口就会立即被写入。默认情况下,文件记录器似乎在超出范围时写入文件,或者在其他神秘的点上,文档没有提到任何关于

票数 44
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18034738

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档