如何将Boost.Log重定向到文件

时间:2013-04-19 10:05:09

标签: c++ logging boost-log

我想在并发应用程序中使用简单的日志文件。我已经下载了Boost.Log v2.0并使用Boost 1.53.0编译了它。

问题是控制台上的Boost.Log输出。我正在使用BOOST_LOG_TRIVIAL(trace)

有没有一种方法可以将BOOST_LOG_TRIVIAL重定向到文件?

1 个答案:

答案 0 :(得分:17)

您可以BOOST_LOG_TRIVIAL使用文件(假设namespace logging = boost::log;

#include <boost/log/core.hpp>
#include <boost/log/trivial.hpp>
#include <boost/log/expressions.hpp>
#include <boost/log/utility/setup/file.hpp>

void init()
{
    logging::add_file_log("sample.log");

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

主要是:

int main(int, char*[])
{
    init();

    BOOST_LOG_TRIVIAL(trace) << "A trace severity message";
 // other types of severity
    BOOST_LOG_TRIVIAL(fatal) << "A fatal severity message";

    return 0;
}