c++ - 如何处理clang中的 "exit-time destructor"警告?

标签 c++ c++11 warnings clang destructor

在我的 C++11 代码中,我在以下情况下收到 clang 警告“声明需要退出时析构函数”:

static const std::map<int, const someStruct> mymap = {
    {1, {
        "A",
        "B",
        "C"
    }},
    {2, {
        "D",
        "E",
        "F"
    }}
};

据我了解,Google 需要一个“退出时析构函数”以确定性的方式销毁 main() 和静态变量,以防止由于“已发布的变量”而导致退出时崩溃。那正确吗?有人能解释得更好吗?

另外:我能做些什么(我不想禁用警告)?上面的代码只在一个线程的上下文中使用。

看起来这就是 Chromium 处理这些情况的方式;这也是我的情况的正确方法吗?

#define CR_DEFINE_STATIC_LOCAL(type, name, arguments) \
  static type& name = *new type arguments

(来源:https://chromium.googlesource.com/chromium/src/+/32352ad08ee673a4d43e8593ce988b224f6482d3/base/basictypes.h)

最佳答案

全局和函数静态对象将在您的应用程序退出时调用其析构函数。这些析构函数是“退出时间析构函数”。并以与它们构建时相反的顺序被调用。

正如您所说,如果其中一些析构函数接触到已销毁的对象,您的程序可能会崩溃。此外,在退出时运行的析构函数会使程序退出速度变慢,而且大多数情况下它们对于程序的正确性并不是必需的(因为当程序退出时,它无论如何都会释放所有内存)。

警告只是指出您有将在退出时运行的析构函数。

您提出的修复将堆分配对象,这不会导致它在程序退出时自动销毁。对于您的情况,这可能已经足够了。

关于c++ - 如何处理clang中的 "exit-time destructor"警告?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14335494/

相关文章:

c++ - 线程的调用堆栈充满了相同的函数调用 -- curl_inet_ntop()

c++ - 为什么 `S x({})` 仅在 GCC 7/C++1z 模式下调用默认构造函数?

c++ - 由于继承而返回拷贝的堆栈?

python - 将 C++ boost::variant 暴露给 Python 时出错

c++ - 带有受歧视 union 和可选<>的奇怪段错误

c++ - 创建自定义 std::streambuf

visual-studio-2010 - Visual Studio 和 Visual C++ IDE 有什么区别

ios - 如何删除警告 : Large title font text style before iOS 11. 0 [5]

c++ - 为什么我在 C++ 中收到针对此基于范围的 for 循环的警告?

ios - ShareKit 测试版问题?