c – 将std ::移动到lambda里面真的有必要吗?

我真的需要在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();

我还是新来的羔羊和rvalue参考,所以最初我试过:

std::transform(std::begin(srcData),&std::move<std::wstring>);

这不行.

我必须把它放在一个lambda里面,还是我缺少一些明显的东西?

解决方法

另一种方法是使用移动迭代器:
std::vector<std::wstring> dstData(std::make_move_iterator(srcData.begin()),std::make_move_iterator(srcData.end()));

或使用移动算法:

std::move(srcData.begin(),srcData.end(),std::back_inserter(dstData));

由于被问及,您可以如何强制原始提案工作:

int main()
{
    std::transform(std::begin(srcData),static_cast<std::wstring&&(*)(std::wstring&)>(&std::move<std::wstring&>));
}

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...