将所有元素从一个std :: list添加到另一个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);
}
}
Run Code Online (Sandbox Code Playgroud)
我想到了std :: copy,但afaik for copy我必须调整目标列表的大小,备份结束迭代器(在调整大小之前)等.
我正在寻找单行声明.
ybu*_*ill 13
this->m_childs.insert(this->m_childs.end(), list->begin(), list->end());
Run Code Online (Sandbox Code Playgroud)
Fre*_*Foo 12
用一个back_insert_iterator.如果std::list<T>是的类型m_childs,
std::copy(list.begin(), list.end(),
std::back_insert_iterator<std::list<T> >(m_childs));
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
18114 次 |
| 最近记录: |