将所有元素从一个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));