forward_list 容器具有和 list 容器相同的特性,即擅长在序列的任何位置进行插入元素或删除元素的操作,但对于访问存储的元素,没有其它容器(如 array、vector)的效率高。

另外,由于单链表没有双向链表那样灵活,因此相比 list 容器,forward_list 容器的功能受到了很多限制。比如,由于单链表只能从前向后遍历,而不支持反向遍历,因此 forward_list 容器只提供前向迭代器,而不是双向迭代器。这意味着,forward_list 容器不具有 rbegin()、rend() 之类的成员函数。
有关迭代器的具体分类以及各种迭代器的具体功能,可以阅读《C++ STL迭代器》一节。

那么,既然 forward_list 容器具有和 list 容器相同的特性,list 容器还可以提供更多的功能函数,forward_list 容器有什么存在的必要呢?

当然有,forward_list 容器底层使用单链表,也不是一无是处。比如,存储相同个数的同类型元素,单链表耗用的内存空间更少,空间利用率更高,并且对于实现某些操作单链表的执行效率也更高。
效率高是选用 forward_list 而弃用 list 容器最主要的原因,换句话说,只要是 list 容器和 forward_list 容器都能实现的操作,应优先选择 forward_list 容器。

#include <forward_list>
using namespace std;

表 2 forward_list 容器可用的成员函数

成员函数 功能
before_begin() 返回一个前向迭代器,其指向容器中第一个元素之前的位置。
begin() 返回一个前向迭代器,其指向容器中第一个元素的位置。
end() 返回一个前向迭代器,其指向容器中最后一个元素之后的位置。
cbefore_begin() 和 before_begin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。
cbegin() 和 begin() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。
cend() 和 end() 功能相同,只不过在其基础上,增加了 const 属性,不能用于修改元素。
empty() 判断容器中是否有元素,若无元素,则返回 true;反之,返回 false。
max_size() 返回容器所能包含元素个数的最大值。这通常是一个很大的值,一般是 232-1,所以我们很少会用到这个函数。
front() 返回第一个元素的引用。
assign() 用新元素替换容器中原有内容。
push_front() 在容器头部插入一个元素。
emplace_front() 在容器头部生成一个元素。该函数和 push_front() 的功能相同,但效率更高。
pop_front() 删除容器头部的一个元素。
emplace_after() 在指定位置之后插入一个新元素,并返回一个指向新元素的迭代器。和 insert_after() 的功能相同,但效率更高。
insert_after() 在指定位置之后插入一个新元素,并返回一个指向新元素的迭代器。
erase_after() 删除容器中某个指定位置或区域内的所有元素。
swap() 交换两个容器中的元素,必须保证这两个容器中存储的元素类型是相同的。
resize() 调整容器的大小。
clear() 删除容器存储的所有元素。
splice_after() 将某个 forward_list 容器中指定位置或区域内的元素插入到另一个容器的指定位置之后。
remove(val) 删除容器中所有等于 val 的元素。
remove_if() 删除容器中满足条件的元素。
unique() 删除容器中相邻的重复元素,只保留一个。
merge() 合并两个事先已排好序的 forward_list 容器,并且合并之后的 forward_list 容器依然是有序的。
sort() 通过更改容器中元素的位置,将它们进行排序。
reverse() 反转容器中元素的顺序。

通过表 2 我们知道,forward_list 容器中是不提供 size() 函数的,但如果想要获取 forward_list 容器中存储元素的个数,可以使用头文件 中的 distance() 函数。举个例子:


#include<iostream>
#include<vector>
#include<cstdio>
#include<string>
#include <forward_list>
#include <iterator>using namespace std;
int main() {forward_list<int> my_words{1, 2, 3, 5};int count = distance(my_words.begin(), my_words.end());cout << count << endl;    return 0;
}

运行结果

4

并且,forward_list 容器迭代器的移动除了使用 ++ 运算符单步移动,还能使用 advance() 函数,比如:

#include <iostream>
#include <forward_list>
using namespace std;
int main()
{std::forward_list<int> values{1,2,3,4};auto it = values.begin();advance(it, 2);while (it!=values.end()){cout << *it << " ";++it;}return 0;
}

运行结果为:

3 4

forward_list相关推荐

  1. C++11中std::forward_list单向链表的使用

    std::forward_list是在C++11中引入的单向链表或叫正向列表.forward_list具有插入.删除表项速度快.消耗内存空间少的特点,但只能向前遍历.与其它序列容器(array.vec ...

  2. C++_STL——list(and forward_list)

    C++_STL--list(and forward_list) 1.类模板 template < class T, class Alloc = allocator<T> > c ...

  3. C++ Primer 5th笔记(9)chapter9 顺序容器 forward_list

    1. 特殊的forward_list 单向链表的删除操作,真正删除的是某个元素后面的值(想想是为什么?) 操作 定义 lst.before_begin() 返回指向链表首元素之前不存在的元素的迭代器, ...

  4. STL的forward_list链表

    forward_list链表 forward_list forward_list::before_begin forward_list::cbefore_begin forward_list forw ...

  5. forward_list容器

    forward_list forward_list(单向链表)序列容器,允许在序列中任何地方进行恒定的时间插入和擦除操作. forward_list(单向链表)被实现为单链表; 单链表可以将它们包含的 ...

  6. 向顺序容器vector、string、deque、list、forward_list中插入\删除元素时迭代器、引用、指针的变化

    1.插入元素 (1)对于vector.string来说,当在某个位置插入元素后,如果内存空间重新分配,则指向任何位置的迭代器.指针.引用都会失效: 如果内存空间没有重新分配,则在插入位置之前的迭代器. ...

  7. forward_list的insert操作

    forward_list的insert函数有以下几个(fobj是有一个forward_list的容器): fobj.insert_after(p,t) //p是个迭代器,指示插入的位置,这个函数是在p ...

  8. 顺序容器(vector、list、string、deque、forward_list)及迭代器、容器适配器

    文章目录 概述 所有容器都支持的操作 迭代器 迭代器支持的操作 迭代器支持的算术运算 容器类型 size_type iterator 和 const_iterator 容器定义和初始化 拷贝初始化 顺 ...

  9. 特殊的forward_list操作

    为了理解forward_list为什么有特殊版本的添加和删除操作,考虑当我们从一个单向链表中删除一个元素时会发生什么.当添加或删除一个元素时,删除或添加的元素之前的那个元素的后继会发生变化.为了添加或 ...

最新文章

  1. 【案例】常驻查询引发的thread pool 性能问题之二
  2. MDK5.29,5.30,5.31,5.32,5.33和各种pack软件包镜像下载
  3. vs(visual studio)调试功能里各个按钮的意义及使用方法?
  4. 控件setVisible为false会导致控件被移除
  5. Linux做软raid10,51CTO博客-专业IT技术博客创作平台-技术成就梦想
  6. SharePoint 2013:解决添加域名后每次都需要登录的问题
  7. Aruba与中国电信国际有限公司达成战略合作 助力中国企业扬帆出海
  8. 天气预测频繁2项集_986天气| 今年冬天比往年更冷?官方回应来了
  9. 在Eclispe中编译运行jbox2d
  10. matlab 绘花,【原创】使用matlab绘制菊花和玫瑰花
  11. 基于隐马尔可夫模型的有监督词性标注
  12. 对,信中介不去信一头猪
  13. 3月12日 对极几何,本征矩阵,基础矩阵,F/E矩阵计算,恢复旋转与平移,三角化视图重建
  14. 大学生 计算机 毕业设计 xx管理系统 毕设(1)
  15. 飞天特效腾云驾雾特效手机软件制作特效视频的教程
  16. jsencrypt php,js加密php解密(一)
  17. 搭建nfs调试arm开发板
  18. python无限循环怎么结束,python的无限循环及退出
  19. Matlab/Simulink仿真问题及技巧汇总【持续更新】
  20. 《暗时间》读后感(一)——确实需要学习一些心理学有关的内容

热门文章

  1. 3D 空间中拟合曲线
  2. 腾讯微博android版本,腾讯微博 Android版
  3. python办公自动化之word表格跨页断行-AllowBreakAcrossPages
  4. 网络营销招生方案及河南大学生高校名单
  5. 无效的证书、相同的序列号、SEC_ERROR_REUSED_ISSUER_AND_SERIAL
  6. MTK,QAC运用minicom和tftp进行uboot
  7. 华为harmonyos2.0哪里下载,华为HarmonyOS最新官方版-华为HarmonyOS2.0最新下载地址-游侠软件下载...
  8. 计算机毕业设计Java金融业撮合交易系统(源码+系统+mysql数据库+lw文档)
  9. linux日志查看/项目日志查看/监控日志
  10. python线性回归预测pm2.5_基于随机森林算法的PM2.5预测