联合共享ptr

Ale*_*llo 7 c++ shared-ptr unions

虽然发生了分段错误,但我想访问联合的共享ptr:

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;
}
Run Code Online (Sandbox Code Playgroud)

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

Que*_*tin 7

你需要初始化std::shared_ptr联盟内部:

union_tmp()
: ptr{} // <--
{}
Run Code Online (Sandbox Code Playgroud)

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

  • 可能值得添加注释,错误的原因是`b.ptr = tmp`调用shared_ptr复制赋值运算符,并假设shared_ptr已经正确初始化. (4认同)

Mr.*_*C64 6

我会std::variant用于安全的C++ "工会"(或者boost::variant如果std::variant没有你的话).

你可以尝试:

std::variant<int, std::shared_ptr<std::vector<int>>> v;
v = std::make_shared<std::vector<int>>();
Run Code Online (Sandbox Code Playgroud)