为什么make_unique不能与unique_ptr :: reset一起使用?

时间:2014-04-01 21:00:59

标签: c++ c++11 unique-ptr c++14

我尝试使用VS2013编译一些C ++代码,而unique_ptr::reset()似乎不适用于make_unique();一个小的可编辑的repro代码片段如下:

#include <memory>
using namespace std;

int main() {
    unique_ptr<int[]> p = make_unique<int[]>(3);
    p.reset(make_unique<int[]>(10));    
}

从命令行编译:

C:\Temp\CppTests>cl /EHsc /W4 /nologo test.cpp

这些是来自MSVC编译器的错误:

test.cpp(6) : error C2280: 'void std::unique_ptr<int [],std::default_delete<_Ty>
>::reset<std::unique_ptr<_Ty,std::default_delete<_Ty>>>(_Ptr2)' : attempting to
reference a deleted function
        with
        [
            _Ty=int []
,            _Ptr2=std::unique_ptr<int [],std::default_delete<int []>>
        ]
        C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\INCLUDE\memory(16
23) : see declaration of 'std::unique_ptr<int [],std::default_delete<_Ty>>::rese
t'
        with
        [
            _Ty=int []
        ]

但是,以下代码似乎编译良好:

p = make_unique<int[]>(10);

这种行为的原因是什么?为什么unique_ptr::operator=()适用于make_unique(),但unique_ptr::reset()不适用?

2 个答案:

答案 0 :(得分:14)

reset()需要一个指针。

您似乎想要的是简单的移动作业

#include <memory>
using namespace std;

int main() {
    unique_ptr<int[]> p = make_unique<int[]>(3);
    p = make_unique<int[]>(10);    
}

某些编译器可能仍然希望您在那里指定std::move(),但并非严格要求。

答案 1 :(得分:8)

因为std::unique_ptr::reset期望管理对象的指针,而不是另一个unique_ptrmake_unique创建了unique_ptr