通过图 1 不难看出,使用链表存储数据最大的特点在于,其并不会将数据进行集中存储(向数组那样),换句话说,链表中数据的存储位置是分散的、随机的,整个链表中数据的线性关系通过指针来维持。图 1 中,H 表示链表的表头。
有关迭代器的具体分类以及各种迭代器的具体功能,可以阅读《C++ STL迭代器》一节。
效率高是选用 forward_list 而弃用 list 容器最主要的原因,换句话说,只要是 list 容器和 forward_list 容器都能实现的操作,应优先选择 forward_list 容器。
#include <forward_list> using namespace std;
创建 forward_list 容器的方式,大致分为以下 5 种。std 命名空间也可以在使用 forward_list 容器时额外注明,两种方式都可以。
std::forward_list<int> values;由于 forward_list 容器在创建后也可以添加元素,因此这种创建方式很常见。
std::forward_list<int> values(10);通过此方式创建 values 容器,其中包含 10 个元素,每个元素的值都为相应类型的默认值(int类型的默认值为 0)。
std::forward_list<int> values(10, 5);如此就创建了一个包含 10 个元素并且值都为 5 个 values 容器。
std::forward_list<int> value1(10); std::forward_list<int> value2(value1);注意,采用此方式,必须保证新旧容器存储的元素类型一致。
//拷贝普通数组,创建forward_list容器 int a[] = { 1,2,3,4,5 }; std::forward_list<int> values(a, a+5); //拷贝其它类型的容器,创建forward_list容器 std::array<int, 5>arr{ 11,12,13,14,15 }; std::forward_list<int>values(arr.begin()+2, arr.end());//拷贝arr容器中的{13,14,15}
成员函数 | 功能 |
---|---|
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() | 反转容器中元素的顺序。 |
std::swap(x , y)
非成员函数(其中 x 和 y 是存储相同类型元素的 forward_list 容器),它和 swap() 成员函数的功能完全相同,仅使用语法上有差异。#include <iostream> #include <forward_list> using namespace std; int main() { std::forward_list<int> values{1,2,3}; values.emplace_front(4);//{4,1,2,3} values.emplace_after(values.before_begin(), 5); //{5,4,1,2,3} values.reverse();//{3,2,1,4,5} for (auto it = values.begin(); it != values.end(); ++it) { cout << *it << " "; } return 0; }运行结果为:
3 2 1 4 5
表 2 中这些成员函数的具体用法,后续学习用到时会具体讲解,感兴趣的读者,也可以通过查阅 STL手册做详细了解。
#include <iostream> #include <forward_list> #include <iterator> using namespace std; int main() { std::forward_list<int> my_words{1,2,3,4}; int count = std::distance(std::begin(my_words), std::end(my_words)); cout << count; return 0; }运行结果为:
4
#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
Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有