联合中的 Shared_ptr

Shared ptr in union

我想访问联合的共享指针,尽管发生分段错误:

struct union_tmp
{
    union_tmp()
    {}
    ~union_tmp()
    {}
    union
    {
        int a;
        std::shared_ptr<std::vector<int>> ptr;
    };
};

int main()
{
    union_tmp b;
    std::shared_ptr<std::vector<int>> tmp(new std::vector<int>);
    b.ptr = tmp; //here segmentation fault happens
    return 0;
}

错误的原因是什么,我该如何避免?

我会使用 std::variant 来获得安全的 C++ "unions"(或者 boost::variant 如果 std::variant 不适合你) .

例如你可以试试:

std::variant<int, std::shared_ptr<std::vector<int>>> v;
v = std::make_shared<std::vector<int>>();

你需要在union里面初始化std::shared_ptr:

union_tmp()
: ptr{} // <--
{}

否则,ptr 保持未初始化状态,调用其赋值运算符会触发未定义的行为。