在xmemory代码的深处抛出C++异常

C++ exception being thrown deep in xmemory code

本文关键字:C++ 异常 深处 xmemory 代码      更新时间:2023-10-16

调用向量的push_back方法时抛出C++异常。在调试器中,异常似乎是在xmemory文件的深处抛出的。以下是我看到异常发生的地方:

// TEMPLATE FUNCTION _Destroy
template<class _Ty> inline
void _Destroy(_Ty _FARQ *_Ptr)
{   // destroy object at _Ptr
    _DESTRUCTOR(_Ty, _Ptr);
}

这似乎不是bad_alloc异常,因为我尝试用bad_alloccatch处理程序将代码包装在try-catch中。代码在那里完成了这一步。它总是进入(…)catch处理程序。如果这不是一个坏的异常,那么会发生什么呢?

xmemory标头是标准C++库的Dinkumware实现的实现细节(例如与MSVC++一起提供)。实际错误不太可能与此特定函数有关。我不知道_DESTRUCTOR宏扩展到什么(使用-E或/E编译器标志可以找到),但它肯定会调用相关类型的析构函数。我会查看这个宏引发的异常,或者检查我的析构函数是否会引发异常。此外,为了更好地处理异常,请尝试捕获std::exception const&,因为建议抛出的每个异常都派生自此类型。对于标准C++库抛出的所有异常,这是绝对正确的。然而,一些系统由于未定义的行为而抛出异常,这些行为可能不是从std::exception派生的(例如,当您的代码最终多次释放内存时)。不幸的是,不遵循从std::exception派生的建议会使调试异常变得相当困难。当您捕捉到std::exception const&时,您可以使用std::exceptionwhat()成员来了解它在做什么。