【发布时间】:2020-05-14 23:49:12
【问题描述】:
在我的项目中,我使用静态对象的构造函数来收集指针,就像注册方法一样。很简单,没有魔法。但是在开始时我遇到了崩溃,我无法解释这里发生了什么。使用 MSVC 或 Clang 在 Windows 上可以重现崩溃,两者都使用 MSVC 标头。给出了以下简单示例。谁能给我一个提示,为什么这会导致问题?
这段代码似乎在 Linux 上的 GCC 和 Clang 中运行良好:
https://gcc.godbolt.org/z/vSKdpW
bar.cpp
static int bar = 1;
static Registration abc(&bar);
foo.cpp
static std::vector<void*> registrations;
void add_to_array(void* p)
{
registrations.push_back(p);
}
foo.h
class Registration
{
public:
Registration(void* op)
{
add_to_array(op);
}
};
执行导致以下崩溃(_Pnext 为 0x8。)
void _Orphan_range(pointer _First, pointer _Last) const { // orphan iterators within specified (inclusive) range
#if _ITERATOR_DEBUG_LEVEL == 2
_Lockit _Lock(_LOCK_DEBUG);
_Iterator_base12** _Pnext = &_Mypair._Myval2._Myproxy->_Myfirstiter;
while (*_Pnext) { <======================= **_Pnext** was 0x8.
有谁知道为什么不能使用静态向量来简单地收集指向对象的指针? foo.cpp 是唯一使用带有push_back 的向量的文件。该数组没有在其他任何地方修改。
【问题讨论】:
-
相关,但之前初始化哪个并不重要。向量在二进制的 r/o 字段中,应该很好地初始化
-
即使是在第一次推送时初始化它的布尔标志也不能解决问题
-
我也订阅了静态初始化问题。我认为布尔测试无关紧要,因为它与向量本身处于相同的条件下。我无法使用 VStudio 2017 重现它。