防止从unique_ptr到shared_ptr的分配

mks*_*der 1 c++ templates stl

我想阻止这样的代码:

unique_ptr<ClassA> captr = unique_ptr<ClassA>(new ClassA());
....
shared_ptr<Base> sptr = move(captr);
Run Code Online (Sandbox Code Playgroud)

此代码应生成编译器错误,但它会在运行时编译并生成双重释放和其他奇怪错误.将unique_ptr分配给shared_ptr毫无意义.如果某些东西被声明为unique_ptr,那么它不应该被共享.但是如果允许将unique_ptr赋值给shared_ptr,那么这个限制就消失了.

不幸的是,当一些函数返回unique_ptr并且有些函数将shared_ptr作为参数时,这个错误太容易了.

问题是:我如何禁止对unique_ptr和shared_ptr的所有模板化变体进行这些赋值,而不管它们被模板化为哪个特定类?

我正在考虑将赋值运算符声明为已删除,但我不确定这样的声明会是什么样子.

Ger*_*ago 9

unique_ptr<ClassA> captr = unique_ptr<ClassA>(new ClassA());
....
shared_ptr<Base> sptr = move(captr);
Run Code Online (Sandbox Code Playgroud)

这确实是正确的代码.这里发生的事情是:

  1. 通过unique_ptrin 捕获资源captr.
  2. 该资源后来被移动到 shared_ptr sptr使您的captr空.
  3. 该资源现在归sptr.
  4. 析构函数unique_ptr不会破坏该资源,因为它不再拥有它.

也许这是简化的代码,你使用自定义删除器,unique_ptr<ClassA>而不是在shared_ptr构造函数中使用该删除器?或者,您的Base类和Derived类可能在内部有资源处理错误?另一种选择可能是你在这两段代码之间做错了.