最近在写 C++时,有这样一个代码需求:在 lambda 中,将一个捕获参数 move 给另外一个变量。 看似一个很简单常规的操作,然而这个 move 动作却没有生效。
具体代码如下:
std::vector<int> vec = {1,2,3};
auto func = [=](){
auto vec2 = std::move(vec);
std::cout << vec.size() << std::endl; // 输出:3
std::cout << vec2.size() << std::endl; // 输出:3
};
代码可在wandbox运行。
我们期望的是,将对变量vec
调用 std::move 后,数据将会移动至变量vec2
, 此时vec
里面应该没有数据了。但是通过打印vec.size()
发现 vec 中的数据并没有按预期移走。
这也就意味着,构造 vec2 时并没有按预期调用移动构造函数,而是调用了拷贝构造函数。
为什么会造成这个问题呢, 我们需要结合std::move
和lambda
的原理看下。
1
GeruzoniAnsasu 2019-09-29 18:44:30 +08:00
|
2
cyhone OP @GeruzoniAnsasu 你这个是因为先 move 了 vec 变量。
|
3
cyhone OP @GeruzoniAnsasu 你这个问题是先 move 了 vec 变量,捕获参数本身就已经在 lambda 外部 move 好了。
而我这篇文章讲的是,在 lambda 内部 move 捕获参数为什么不生效的问题。根据这个特殊的 case 讲的。 咱们这是两个问题。 |
4
wutiantong 2019-10-09 10:24:11 +08:00
@GeruzoniAnsasu 是楼主不会写 C++
|