Boost.Log: Почему он показывает дубликат сообщения?

Я изучаю библиотеку Boost.Log. Я хочу отправлять сообщения в файл и std::clog. У меня есть следующий класс:

class logger
{
    public:
        explicit logger(
            const std::string& tag,
            const std::string& file,
            bool console
        )
        {
            boost::log::register_simple_formatter_factory< boost::log::trivial::severity_level, char >("Severity");

            std::string the_format = "[%TimeStamp%] (%LineID%) [%Severity%]";
            if(!tag.empty()) {
                m_log_.add_attribute(
                    "Tag",
                    boost::log::attributes::constant< std::string >( tag )
                );
                the_format += " [%Tag%]";
            }

            the_format += ": %Message%";

            if(console) {
                boost::log::add_console_log(
                    std::clog,
                    boost::log::keywords::auto_flush = true,
                    boost::log::keywords::format = the_format
                );
            }

            if(!file.empty()) {
                boost::log::add_file_log(
                    boost::log::keywords::file_name = file,
                    boost::log::keywords::auto_flush = true,
                    boost::log::keywords::open_mode = (std::ios::out | std::ios::app),
                    boost::log::keywords::format = the_format
                );
            }

        }

        ~logger(void)
        { }

        void log(
            const std::string& msg
        )
        {
            BOOST_LOG_SEV ( m_log_, boost::log::trivial::info ) << msg;
        }

    private:
        boost::log::sources::severity_logger< boost::log::trivial::severity_level > m_log_;

}; // logger

У меня есть следующая функция main():

void x()
{
    logger lg("omega", "", true);
    lg.log( "Goodbye" );
}

int main(int argc, char** argv)
{
    logger lg( "alfa", "", true );
    lg.log( "Hello world!!!");
    x();
    return 0;
}

Я не понимаю, почему высвечивается повторяющееся сообщение: "Hello world!!!":

[2016-Aug-23 17:51:36.852912] (1) [info] [alfa]: Hello world!!!
[2016-Aug-23 17:51:36.853359] (2) [info] [omega]: Goodbye
[2016-Aug-23 17:51:36.853359] (2) [info] [omega]: Goodbye

ОБНОВЛЕНИЕ. Извините, пример был неполным.


person Juan Solo    schedule 23.08.2016    source источник
comment
Какую версию буста вы используете? Я не могу воспроизвести это с 1.58. Какая платформа?   -  person isanae    schedule 23.08.2016
comment
@isanae, извините, пример был неполным. Я использую версию 1.60 и ОС GNU/Linux.   -  person Juan Solo    schedule 23.08.2016


Ответы (1)


Конструктор logger вызывает add_console_log() и add_file_log(). Если вы сконструируете logger дважды, эти функции также будут вызываться дважды. Поскольку они добавляют глобальные приемники, каждая запись журнала будет дублироваться дважды на консоли и в вашем файле.

int main(int argc, char** argv)
{
    logger lg1("1", "", true);
    logger lg2("2", "", true);
    logger lg3("3", "", true);
    logger lg4("4", "", true);

    lg1.log("test");
}

Это выведет:

[2016-Aug-23 13:25:56.468382] (1) [info] [1]: test
[2016-Aug-23 13:25:56.468382] (1) [info] [1]: test
[2016-Aug-23 13:25:56.468382] (1) [info] [1]: test
[2016-Aug-23 13:25:56.468382] (1) [info] [1]: test

Вы, вероятно, хотите, чтобы какой-то счетчик ссылок или флаг вызывали эти функции только один раз.

person isanae    schedule 23.08.2016
comment
@isanea: Спасибо, проблема устранена. Еще одна вещь, если я использую потоки в примере, как предотвратить дублирование вывода в каждом потоке? - person Juan Solo; 25.08.2016
comment
@JuanSolo (Убедитесь, что вы правильно вводите имена пользователей, или выберите их из всплывающего списка. Я не получил уведомление о вашем сообщении.) Что вы имеете в виду? Проблема в том, что add_console_log() вызывается несколько раз, а не потоки. - person isanae; 28.08.2016
comment
Теперь я использую файлы в примере. В этом случае на выходе первого логгера появляется Goodbye. В документации сказано, что такое поведение правильное. Могу ли я изменить это поведение? - person Juan Solo; 29.08.2016
comment
@JuanSolo Я не понимаю, какое поведение ты хочешь изменить. Если вы вызовете add_console_log() только один раз, вывод появится только один раз. - person isanae; 29.08.2016
comment
: Я настраиваю логгер на использование файлов (я не использую функцию add_console_log(), я использую только функцию add_file_log()). Здесь вы можете увидеть пример (это не исполняемый файл, потому что я не знаю, как писать файлы в колиру но можно понять о чем я прошу). - person Juan Solo; 30.08.2016
comment
@JuanSolo Я не понимаю твоего вопроса. Поскольку он кажется не связанным с вашим первоначальным, я предлагаю вам запросить новый с более подробной информацией. Вы можете добавить комментарий со ссылкой на новый вопрос здесь, я постараюсь помочь больше. - person isanae; 30.08.2016
comment
stackoverflow.com/questions/39247778/ - person Juan Solo; 31.08.2016