我正在尝试使用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”写入日志的行时,我收到一条说“Debug Assertion Failed!”的崩溃。断言位于f:\ dd \ vctools \ crt_bld_self_64_amd64 \ crt \ src \ write.c第67行。失败的断言是
fh >= 0 && (unsigned)fh < (unsigned)_nhandle
我创建了logs目录和bar.log文件以确保它存在。我还确认我的应用程序和库都是作为64位多线程调试DLL构建的。 log4cpp源中没有64位构建,因此我基于32位构建配置创建了一个。我正在使用最新版本的log4cpp。
答案 0 :(得分:1)
这是老帖子,但我想这个问题的解决方案可能对某人有用。
很可能你只是忘记创建代码中的目录“logs”。
这是封闭流的问题:记录器不会自动为您的日志创建目录,因此,没有目录 - &gt;没有文件 - &gt;打开文件失败 - &gt;无效的文件处理程序 - &gt;例外。您应该手动创建目录。宏断言,没有更多的信息是悲伤的。
答案 1 :(得分:0)
刚刚发现了这个问题并试图得到这个断言。 我已经在 MSVC2010 中构建了log4cpp(ver 1.1)库和 user1229080 对Win32和x64平台的测试,并且没有断言。
我添加了几行来编译,并从文件路径中删除了“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 ++?