首页 > 后端开发 > C++ > 正文

c++的std::forward_list是什么 单向链表容器的使用【STL详解】

裘德小鎮的故事
发布: 2025-12-19 11:32:02
原创
609人浏览过
std::forward_list 是 C++11 引入的单向无哨兵链表,内存更紧凑、头部操作高效,但不支持随机访问、反向迭代和 O(1) size()(C++17 起可选),适用于内存敏感、头部频繁增删且单向遍历的场景。

c++的std::forward_list是什么 单向链表容器的使用【stl详解】

std::forward_list 是 C++11 引入的标准模板库(STL)容器,它是一个不带尾指针的单向链表,只支持从头到尾的单向遍历,不提供随机访问,也不保存自身大小(size() 在 C++11 中默认是 O(n) 操作,C++17 起可选实现为 O(1),但标准仍不强制)。

为什么用 forward_list 而不是 list?

相比 std::list(双向链表),forward_list 内存更紧凑:每个节点只存一个指针(指向下一节点),没有 prev 指针,也没有额外的哨兵节点(sentinel node)。这意味着:

  • 每个元素内存开销更小(尤其对小对象,如 intchar*
  • 插入/删除操作在已知位置时,性能略优(少一次指针更新)
  • 但不支持反向迭代、无法直接获取长度、不能通过下标访问

基本用法与常见操作

声明和初始化:

  std::forward_list fl = {1, 2, 3};
  std::forward_list<:string> names;
  fl.push_front(0); // 只能从前端插入

立即学习C++免费学习笔记(深入)”;

关键限制与对应操作:

Tellers AI
Tellers AI

Tellers是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。

Tellers AI 136
查看详情 Tellers AI
  • 没有 push_back() —— 需用 insert_after() 在末尾前插入,或遍历到末尾再插
  • 没有 pop_back() —— 删除末尾需先找到倒数第二个节点,再 erase_after()
  • 所有修改操作都围绕 before 位置:如 insert_after(it, val)erase_after(it)
  • 迭代器是单向的:forward_list::iterator 只支持 ++,不支持 -- 或 +n

实用技巧:高效插入与拼接

因为没有尾指针,手动维护尾迭代器可避免重复遍历:

  std::forward_list a = {1, 2};
  auto tail = std::prev(a.end()); // C++11 起可用 prev,但注意 forward_list::end() 不可递减
  // 更安全做法:用 before_begin()
  a.insert_after(tail, 3); // 插入到末尾

拼接两个 forward_list 推荐用 splice_after()

  • a.splice_after(pos, b):把 b 的所有元素插入到 a 中 pos 后面,b 变为空
  • O(1) 时间,不复制元素,比循环 insert_after 高效得多

什么时候该选 forward_list?

适用场景很明确:

  • 频繁在头部插入/删除,且极少需要随机访问或反向遍历
  • 内存敏感环境(嵌入式、高频小对象缓存),且容器平均长度不长
  • 算法逻辑天然符合单向流式处理(如解析 token 链、事件队列、LRU 前半段)

不推荐用于:需要 size()、需要 back()、需要稳定下标、或常做尾部操作的场景——此时 vectorlist 更合适。

以上就是c++++的std::forward_list是什么 单向链表容器的使用【STL详解】的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号