贝利信息

c++ std::forward_list怎么用 c++单向链表容器【详解】

日期:2026-01-06 00:00 / 作者:裘德小鎮的故事
std::forward_list 是 C++11 引入的轻量单向链表,仅支持前向遍历和头/指定位置插入(无 push_back),内存开销小于 list,size() 在 C++17 前非 O(1),推荐用 empty() 判空,适用于内存敏感、高频头插删场景。

std::forward_list 是 C++11 引入的单向链表容器,底层基于单链表实现,只支持前向遍历(从头到尾),不提供随机访问、也不保存尾指针,因此内存开销比 std::list 更小,插入/删除操作常数时间,但不支持 size()(C++11 中无 O(1) 大小记录,需手动计数或遍历)。

初始化和基本操作

声明方式与其它 STL 容器类似,但注意它没有 push_back()(因为无尾指针),只能在头部或指定位置前插入:

遍历和访问元素

只能用前向迭代器,且不支持 operator[]at()

删除和修改操作

所有删除都通过迭代器完成,注意迭代器失效规则(仅被删节点迭代器失效,其余有效):

与其他链表对比和使用建议

std::forward_list 的设计目标是极致轻量,适合对内存敏感、频繁头插/头删、且不需要反向遍历或快速获取长度的场景: