news 2026/5/30 23:57:00

C++中的forward_list容器详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++中的forward_list容器详解

C++中的forward_list容器详解

1.forward_list概述

forward_list是C++11引入的单向链表容器,相比list更加节省空间,但只支持单向遍历。它是最简单的链表结构,每个元素只包含指向下一个元素的指针。

2. 基本特性

  • 单向链表:每个元素只包含指向下一个元素的指针
  • 高效插入/删除:在已知位置插入/删除是O(1)O(1)O(1)时间复杂度
  • 无随机访问:不支持下标操作和反向遍历
  • 最小内存开销:相比list节省一个指针的空间
  • size()操作:为节省空间不维护大小信息

3. 头文件与声明

#include<forward_list>usingnamespacestd;forward_list<int>flst1;// 空forward_listforward_list<string>flst2(10);// 包含10个默认构造的stringforward_list<double>flst3(5,3.14);// 包含5个3.14forward_list<char>flst4={'a','b','c'};// 初始化列表

4. 构造函数与初始化

4.1 默认构造

forward_list<int>flst;

4.2 填充构造

forward_list<int>flst(10);// 10个默认初始化的int(0)forward_list<int>flst(5,100);// 5个100

4.3 范围构造

intarr[]={1,2,3};forward_list<int>flst(arr,arr+3);

4.4 拷贝构造

forward_list<int>flst2(flst1);

5. 容量操作

5.1empty()

if(flst.empty()){cout<<"Forward_list is empty";}

5.2max_size()

cout<<flst.max_size();// 返回forward_list可容纳的最大元素数

6. 元素访问

6.1front()

flst.front()=5;// 修改第一个元素intfirst=flst.front();// 访问第一个元素

7. 修改操作

7.1push_front()

flst.push_front(5);// 在头部插入5

7.2pop_front()

flst.pop_front();// 删除头部元素

7.3insert_after()

autoit=flst.insert_after(flst.before_begin(),15);// 在头部插入15flst.insert_after(it,{1,2,3});// 在指定位置后插入多个元素

7.4erase_after()

flst.erase_after(flst.before_begin());// 删除第一个元素flst.erase_after(it,flst.end());// 删除从it到end的所有元素

7.5clear()

flst.clear();// 清空所有元素

7.6swap()

forward_list<int>flst2;flst.swap(flst2);// 交换两个forward_list的内容

8. 特殊操作

8.1splice_after()

forward_list<int>flst2={4,5,6};flst.splice_after(flst.before_begin(),flst2);// 将flst2所有元素移动到flst头部

8.2remove()

flst.remove(5);// 删除所有值为5的元素

8.3remove_if()

flst.remove_if([](intn){returnn%2==0;});// 删除所有偶数

8.4unique()

flst.unique();// 删除连续重复元素

8.5merge()

forward_list<int>flst2={4,5,6};flst.sort();flst2.sort();flst.merge(flst2);// 合并两个已排序forward_list

8.6sort()

flst.sort();// 升序排序flst.sort(greater<int>());// 降序排序

8.7reverse()

flst.reverse();// 反转forward_list

9. 迭代器

9.1before_begin()

autoit=flst.before_begin();// 获取第一个元素前的位置

9.2begin()&end()

for(autoit=flst.begin();it!=flst.end();++it){cout<<*it<<" ";}

10. 完整示例

#include<iostream>#include<forward_list>#include<algorithm>usingnamespacestd;intmain(){// 创建并初始化forward_listforward_list<int>flst={2,3,4};// 头部操作flst.push_front(1);// 头部插入1// 访问元素cout<<"First element: "<<flst.front()<<endl;// 插入元素autoit=flst.insert_after(flst.begin(),5);// 在第二个位置插入5flst.insert_after(it,{7,8,9});// 在5后面插入7,8,9// 删除元素flst.pop_front();// 删除头部元素flst.remove(8);// 删除所有8// 特殊操作forward_list<int>flst2={10,11,12};flst.splice_after(flst.before_begin(),flst2);// 合并flst2到flstflst.sort();// 排序flst.unique();// 去重// 遍历forward_listcout<<"All elements: ";for(intnum:flst){cout<<num<<" ";}cout<<endl;// 容量信息cout<<"Is empty: "<<(flst.empty()?"Yes":"No")<<endl;return0;}

11. 性能提示

  1. 在已知位置插入/删除元素性能很好(O(1)O(1)O(1))
  2. 查找元素需要遍历(O(n)O(n)O(n))
  3. 迭代器在插入/删除操作后仍然有效(除非删除的是迭代器指向的元素)
  4. list更节省内存(每个节点少一个指针)
  5. 适合只需要单向遍历且对内存敏感的场合
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 22:24:07

TI C2000电机控制器ADC采样精度优化操作指南

TI C2000电机控制器ADC采样精度优化实战指南在高性能电机控制领域&#xff0c;“看得清”才能“控得准”。电流和电压的实时感知能力&#xff0c;直接决定了FOC&#xff08;磁场定向控制&#xff09;算法能否精准解耦、转矩脉动是否可控、系统效率能不能拉到极限。而这一切的基…

作者头像 李华
网站建设 2026/5/29 22:13:01

AI产品经理也该懂的技术:TensorRT如何影响用户体验

AI产品经理也该懂的技术&#xff1a;TensorRT如何影响用户体验 在一款智能客服应用的测试中&#xff0c;团队发现用户平均等待时间超过800毫秒——这个数字看似微小&#xff0c;却让转化率下降了近15%。进一步排查发现&#xff0c;问题并不出在模型本身&#xff0c;而是推理过程…

作者头像 李华
网站建设 2026/5/28 19:48:04

一文搞懂TensorRT核心机制:层融合、内存复用与内核实例化

一文搞懂TensorRT核心机制&#xff1a;层融合、内存复用与内核实例化 在现代AI系统中&#xff0c;训练只是第一步&#xff0c;真正决定用户体验和商业价值的&#xff0c;往往是推理阶段的表现。一个准确率高达99%的模型&#xff0c;如果每次预测需要200毫秒&#xff0c;在实时视…

作者头像 李华
网站建设 2026/5/28 14:30:26

智能体深度解析:Agent中的多代理协同的优势和难点是什么?

虽然单体 Agent 架构对于定义明确的问题可能是有效的&#xff0c;但在面对复杂的多领域任务时&#xff0c;其能力往往受到限制。多 Agent 协作模式通过将系统构建为由不同专门化 Agent 组成的协作集合来解决这些限制。 这种方法基于任务分解原则&#xff0c;其中高级目标被分解…

作者头像 李华
网站建设 2026/5/28 15:26:26

从实验室到生产线:大模型必须经历的TensorRT改造

从实验室到生产线&#xff1a;大模型必须经历的TensorRT改造 在AI系统真正上线之前&#xff0c;大多数工程师都经历过这样的窘境&#xff1a;一个在论文或实验中表现惊艳的大模型&#xff0c;一旦部署到生产环境&#xff0c;立刻变得“笨重迟缓”——响应慢、吞吐低、显存爆、成…

作者头像 李华
网站建设 2026/5/28 14:30:27

iOS核心开发手册【1.1】

1.3 解决方案&#xff1a;添加拖动手势识别器用手势识别器也可以实现与解决方案1-1相同的交互功能&#xff0c;而且还不用直接编写触摸处理程序[1]。拖动手势识别器可以侦测拖曳手势。只要iOS系统检测到拖动手势&#xff0c;它就会触发你所指定的回调方法。解决方案1-2的代码与…

作者头像 李华