首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >调试断言在试图写入Log4cpp流时失败

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

Stack Overflow用户
提问于 2013-04-12 13:22:10
回答 2查看 2.8K关注 0票数 0

我试图以以下方式使用log4cpp启用日志记录。

代码语言:javascript
复制
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“写到日志的行时,我会遇到一个崩溃,上面写着"Debug断言失败了!”断言在f:\dd\vctools\crt_bld_self_64_amd64\crt\src\write.c第67行中。失败的断言是

代码语言:javascript
复制
fh >= 0 && (unsigned)fh < (unsigned)_nhandle

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

EN

回答 2

Stack Overflow用户

发布于 2013-08-06 09:09:09

这是一篇老文章,但我想解决这个问题对某些人是有用的。

很可能您只是忘记创建代码中的目录“日志”

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

票数 1
EN

Stack Overflow用户

发布于 2013-10-17 15:13:00

刚刚发现了这个问题并试图得到这个结论。我构建了log4cpp (ver1.1)库和user1229080MSVC2010中对Win32和x64平台的测试,但没有得到任何断言。

我添加了几行代码来编译它,并从文件路径中删除了“log”dir,以消除与缺少目录相关的问题:

代码语言:javascript
复制
#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++上遇到了断言?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15972525

复制
相关文章

相似问题

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