草庐IT

something_bad_happened_exception

全部标签

c++ - 程序以 std::bad_alloc 终止

我正在运行一个C++程序,它在任意点死于std::bad_alloc,这取决于指定的输入。以下是关于该计划的一些观察/要点:对于较短的运行(运行时间取决于输入),程序会正常完成。问题只出现在较大的运行中。该程序没有任何可检测到的内存泄漏。这已通过Valgrind/Memcheck进行了较小的运行检查。此外,我的整个代码没有任何指针(所有动态分配都是由库完成的,例如,在std::vector和std::string中;它是这些库类中的分配失败),因此内存泄漏的可能性极小。几个对象在循环中分配,然后移动到容器中。这些对象中有几个是为了在程序快结束之前一直存在。我怀疑堆碎片可能是个问题(请参

c++ - 在 Visual Studio 中调用 std::swap 时的 std::bad_function_call

我正在尝试将我的代码从Linux移植到Windows。但是,对于VisualStudio,我的代码因以下错误而崩溃:MicrosoftC++exception:std::bad_function_callatmemorylocation这是我的代码:#includeclassFoo{public:Foo(int):m_deleter{[](){}}{}Foo(constFoo&)=delete;Foo(Foo&&)=default;Foo&operator=(constFoo&)=delete;Foo&operator=(Foo&&)=default;~Foo(){m_deleter(

c++ - 异常 : bad_weak_ptr while shared_from_this

当我这样做时出现异常:std::bad_weak_ptr->shared_from_this()templateclasspainter_record_t{.......private:std::shared_ptr_owner;}这里我想在构造函数中设置“问题”对象:templateclassstream_record_t:publicpainter_record_t{public:stream_record_t(std::shared_ptrowner):painter_record_t(owner){//...}}我有基类:classi_painter_t{public:virt

c++ - 为什么在抛出 'std::bad_alloc' 实例后调用终止?

每1秒,函数工作一次。我的系统是linux。奔跑突然死亡。-----global-------staticintarrayNum[33000];-------------------function(){unsignedshortint**US_INT;US_INT=newunsignedshortint*[255];for(inti=0;i程序停止。和留言↓在抛出“std::bad_alloc”的实例后终止调用what():std::bad_alloc 最佳答案 bad_alloc异常是由内存分配失败触发的(因此您的new之一)。

c++ - 在这个例子中,std::variant 是如何变成 valueless_by_exception 的?

这是受cppreference中示例启发的示例structS{operatorint(){throw42;}};intmain(){variantv{12.f};//OKcout(S());//vmaybevalueless}catch(...){}cout对于一个编译器,我试过它的输出false,true意味着emplace导致变体变得毫无值(value)我不明白这是怎么发生的。特别是我根本不明白为什么emplace被调用,我希望程序甚至不会调用它,因为从S到int参数的转换会抛出。 最佳答案 注意相关std::variant::

c++ - 抛出 "bad_alloc"的最常见原因是什么?

是否有更频繁的内存相关错误抛出bad_alloc?我知道这意味着内存分配失败,但在代码中导致这种情况的最常见错误是什么? 最佳答案 编辑:其他评论者指出了一些有趣的场景。为了完整起见,我将它们添加到我的回复中。情况一:内存不足我的理解是,只要运算符new和new[]无法为对象或变量分配内存,就会抛出bad_alloc。如果您新建了一堆对象并忘记在它们超出范围之前删除它们(即,您的代码疯狂地泄漏),就会发生这种情况。案例2:一举分配大量内存分配大块内存(如1000x1000x1000double矩阵的情况)可能会失败,因为它需要一个该

c++ - Xcode4 : "bad codegen, pointer diff" linker error again

这个问题与此相关:"badcodegen,pointerdiff"linkererrorwithXcode4和"badcodegen,pointerdiffinboost"errorin32-bitbuild和XCode3.2.6and4linkererrorsld:badcodegen,pointerdiffin...toglobalweaksymbol我目前正在将我的所有项目升级到Xcode4,但我遇到了一些奇怪的事情。-仅当我构建通用二进制文件或32位版本时才会出现上述错误。如果我只坚持64位,一切正常。我正在自己构建一个自定义静态库,现在我不在该代码中使用任何可见性设置(即at

C++ fstream : throwing exception when reaching eof

我想读取两个文件,直到读到其中一个文件的末尾。如果出现问题,fstream应该抛出异常。问题是,设置eof位时也会设置坏位或失败位。ifstreaminput1;input1.exceptions(ios_base::failbit|ios_base::badbit);input1.open("input1",ios_base::binary|ios_base::in);ifstreaminput2;input2.exceptions(ios_base::failbit|ios_base::badbit);input2.open("input2",ios_base::binary|io

c++ - 如何将消息附加到 std::exception?

我想做以下事情:std::stringfileName="file";std::ifstreamin(fileName.c_str());in.exceptions(std::istream::failbit);try{loadDataFrom(in);}catch(std::ios_base::failure&exception){std::stringlocation=std::string("infile\n")+fileName;//appendthe"location"totheerrormessage;throw;}如何将错误消息附加到异常? 最

c++ - 安置新的和异常(exception)

“placementnew”运算符声明如下:void*operatornew(std::size_tsize,void*ptr)noexcept;但是虽然它不涉及任何实际分配,因此消除了错误的分配异常,但指针仍然可能指向错误的位置,在这种情况下,人们会期望得到一个范围或溢出/下溢错误,但是它被声明为noexcept的事实不会直接终止执行吗?这是否也意味着在C++11之前放置new将抛出并尝试处理std::unexpected而不是直接处理std::set_unexpected崩溃?“以防万一”,难道不应该有大量的placementnew吗? 最佳答案