我真的必须在lambda中封装std :: move调用吗?
std::list<std::wstring> srcData = GetData(); // implementation not important
std::vector<std::wstring> dstData;
dstData.reserve(srcData.size());
std::transform(std::begin(srcData), std::end(srcData), std::back_inserter(dstData),
[](std::wstring& guid) -> std::wstring { return std::move(guid); });
srcData.clear();
我还是lambdas和rvalue引用的新手,所以最初我尝试过:
std::transform(std::begin(srcData), std::end(srcData),
std::back_inserter(dstData), &std::move<std::wstring>);
哪个不起作用。
我是否必须将移动放在lambda中,或者我错过了一些明显的东西?
答案 0 :(得分:13)
另一种方法是使用移动迭代器:
std::vector<std::wstring> dstData(std::make_move_iterator(srcData.begin()),
std::make_move_iterator(srcData.end()));
或使用move
算法:
std::move(srcData.begin(), srcData.end(), std::back_inserter(dstData));
自从被问及以来,您可以通过以下方式强制执行原始提案:
int main()
{
std::transform(std::begin(srcData),
std::end(srcData),
std::back_inserter(dstData),
static_cast<std::wstring&&(*)(std::wstring&)>(&std::move<std::wstring&>));
}