我是靠谱客的博主 可耐舞蹈,最近开发中收集的这篇文章主要介绍forward_list详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

forward_list在头文件<forward_list>中,与list类似,区别就是list时双链表,forward_list是单链表,forward_list只支持前向迭代。在访问第一个元素的时候用的是

before_begin(),这个方法返回的是第一个元素的前一个元素,也就是虚设的元素,不能解引用,因为这个元素是假设出来的,所以+1就可以访问第一个元素了。

#include <iostream>
#include <forward_list>

int main() {
    std::forward_list<int> forList1({1,2,3,4});
    std::forward_list<int> forList2({5,6,7});
    std::forward_list<int> forList3({8,9,10});

    forList2.splice_after(forList2.before_begin(),forList1);
    forList2.push_front(0);

    auto iter = forList2.before_begin();
    auto iterTemp = iter;

    while(++iterTemp != std::end(forList2))
    {
        ++iter;
    }
//    auto iter = std::end(forList2);
    forList2.insert_after(iter,std::begin(forList3),std::end(forList3));

    for(auto temp : forList2)
    {
        std::cout << temp << " ";
    }

    return 0;
}

结果是:

0 1 2 3 4 5 6 7 8 9 10

因为这是一个forward_list没有后向迭代,所以不能用std::end(forList2);只能由前向迭代++,到end.遍历整个forward_list;

 

转载于:https://www.cnblogs.com/boost/p/10396855.html

最后

以上就是可耐舞蹈为你收集整理的forward_list详解的全部内容,希望文章能够帮你解决forward_list详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部