将所有元素从一个std :: list添加到另一个的“正确”方法是什么?
void Node::addChilds(const NodeList *list) { for(NodeList::const_iterator i = list->begin(); i != list->end(); ++i) { this->m_childs.push_back(*i); } }
我想到了std :: copy,但afaik为副本我必须调整目标列表的大小,备份结束迭代器(在调整大小之前)等.
我正在寻找一条单行语句.
解决方法
使用
back_insert_iterator
.如果std :: list< T>是m_childs的类型,std::copy(list.begin(),list.end(),std::back_insert_iterator<std::list<T> >(m_childs));
原文地址:https://www.jb51.cc/c/113121.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。