0

我正在尝试通过以下方式使用 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";
}

当我到达尝试将“测试”写入日志的行时,我得到一个显示“调试断言失败!”的崩溃。断言在 f:\dd\vctools\crt_bld_self_64_amd64\crt\src\write.c 第 67 行。失败的断言是

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

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

4

2 回答 2

1

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

很可能您只是忘记在代码中创建目录“logs”

这是关闭流的问题:记录器不会为您的日志自动创建目录,因此,没有目录 -> 没有文件 -> 打开文件失败 -> 文件处理程序无效 -> 异常。您应该手动创建目录。宏断言和没有更多信息是可悲的。

于 2013-08-06T09:09:09.067 回答
0

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

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

#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++ 上遇到了断言?

于 2013-10-17T15:13:00.867 回答