加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 将元素从一个列表添加到另一个列表的简单方法

发布时间:2020-12-16 05:58:06 所属栏目:百科 来源:网络整理
导读:将所有元素从一个std :: list添加到另一个的“正确”方法是什么? voidNode::addChilds(const NodeList *list){ for(NodeList::const_iterator i = list-begin(); i != list-end(); ++i) { this-m_childs.push_back(*i); }} 我想到了std :: copy,但afaik为副
将所有元素从一个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));

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读