我真的需要在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&>)); }
原文地址:https://www.jb51.cc/c/112037.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。