为什么无法从pair中返回unique_ptr?

7
为什么我不能从pair返回unique_ptr?
#include <iostream>
#include <memory>
#include <utility>

using namespace std;

unique_ptr<int> get_value() {
    pair<unique_ptr<int>, int> p(unique_ptr<int>(new int(3)), 4);
    return p.first;
}

int main(void) {
    cout << *get_value() << endl;
    return 0;
}

当我尝试使用g++ 4.6编译这个代码时,出现以下错误:
../main.cpp: In functionstd::unique_ptr<int> get_value()’:
../main.cpp:9:11: error: use of deleted functionstd::unique_ptr<_Tp, _Dp>::unique_ptr(const std::unique_ptr<_Tp, _Dp>&) [with _Tp = int, _Dp = std::default_delete<int>, std::unique_ptr<_Tp, _Dp> = std::unique_ptr<int>]’
/usr/include/c++/4.6/bits/unique_ptr.h:256:7: error: declared here
make: *** [main.o] Error 1

我不理解这个错误信息。

1
std::unique_ptr 是移动语义的。 - chris
这个怎么不是移动语义(move-only)呢? - dspyz
1个回答

9

std::unique_ptr没有拷贝构造函数,而且你返回它的方式(作为局部对象的成员)不能自动移动。在这种情况下,你需要手动指定移动。

return std::move(p.first);

我如何知道什么可以自动移动? - dspyz
1
@dspyz:给我一分钟查找参考资料,但它是符合返回值优化条件的相同情况。 - Benjamin Lindley
6
我会尽力为您翻译:@dspyz: 请查看第12.8段的31和32:http://isocpp.org/files/papers/N3797.pdf。 - Benjamin Lindley
1
@dspyz,进一步解释一下,如果您只是执行了std::unique_ptr<int> p(new int(3)); return p;,那么它就是合格的。 - chris

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接