试图写入Log4cpp流时调试断言失败

Debug Assertion Fails When Trying to Write to Log4cpp Stream

本文关键字:调试 断言 失败 Log4cpp      更新时间:2023-10-16

我正在尝试使用log4cpp以以下方式启用日志记录。

class Foo
{
    private: 
        log4cpp::Appender* _logAppender;
        log4cpp::Layout* _logAppenderLayout;
}
Foo::Foo()
{
    _logAppender = new log4cpp::FileAppender("foo", "logs/bar.log"));
    _logAppenderLayout = new log4cpp::BasicLayout();
    _logAppender.setLayout(_logAppenderLayout);
    log4cpp::Category::getRoot().setPriority(log4cpp::Priority::DEBUG);
    log4cpp::Category::getRoot().addAppender(_logAppender);
    // Crash on line below.
    log4cpp::Category::getRoot().debugStream() << "test";
}

当我到达我试图将"test"写入日志的行时,我得到一个崩溃,说"调试断言失败!"断言在f:ddvctoolscrt_bld_self_64_amd64crtsrcwrite.c第67行。失败的断言是

fh >= 0 && (unsigned)fh < (unsigned)_nhandle

我已经创建了logs目录和bar.log文件,以确保它存在。我还确认了我的应用程序和库都是作为64位多线程调试dll构建的。在log4cpp源代码中没有64位构建,所以我基于32位构建配置创建了一个。我使用的是最新版本的log4cpp

这是一个旧的帖子,但我想这个问题的解决方案可能对某些人有用。

很可能你只是忘记在代码中创建目录"logs"

这是关闭流的问题:logger不会为您的日志自动创建目录,因此,no directory -> no file -> open file failed -> invalid file handler ->异常。您应该手动创建目录。

刚刚发现这个问题,并试图得到这个断言。我在MSVC2010中构建了log4cpp (ver 1.1)库和user1229080的Win32和x64平台测试,没有任何断言。

我添加了几行来编译它,并从文件路径中删除了"logs"dir,只是为了摆脱与缺失目录相关的问题:

#include "stdafx.h"
#include <log4cpp/Category.hh>
#include <log4cpp/FileAppender.hh>
#include <log4cpp/OstreamAppender.hh>
#include <log4cpp/BasicLayout.hh>
class Foo
{
    private:
        log4cpp::Appender* _logAppender, *_conAppender;
        log4cpp::Layout* _logAppenderLayout;
    public:
        Foo();
};
Foo::Foo()
{
    _conAppender = new log4cpp::OstreamAppender("con", &std::cout);
    _logAppender = new log4cpp::FileAppender("foo", "bar.log");
    _logAppenderLayout = new log4cpp::BasicLayout();
    _logAppender->setLayout(_logAppenderLayout);
    log4cpp::Category::getRoot().setPriority(log4cpp::Priority::DEBUG);
    log4cpp::Category::getRoot().addAppender(_logAppender);
    log4cpp::Category::getRoot().addAppender(_conAppender);

    // Crash on line below. (but not in msvc2010)
    log4cpp::Category::getRoot().debugStream() << "test" << log4cpp::eol;
}
int main(int argc, char* argv[]) {
    Foo f;
    return 0;
}

你在哪个版本的visual c++上遇到了这个断言?