如下一个程序进行演示讲解
#include <forward_list> 需要包含该头文件
template <typename T>
void print(T Begin, T end)
{
for (T i = Begin; i != end; ++i)
{
std::cout << *i << std::endl;
}
std::cout << std::endl;
}
int main()
{
std::forward_list<int> obj(5); 声明一个当前有五个元素的单向链表
int temp = 0;
for (auto i = obj.begin(); i != obj.end(); i++)
{
obj.push_front(temp); 相当于头插法
temp++;
}
for (auto i = obj.begin(); i != obj.end(); i++)
{
std::cout << *i << std::endl; 遍历打印
}
struct std::forward_iterator_tag 该迭代器是一个单向迭代器,只能从头部开始使用,支持++ * = 运算符
auto it = obj.begin(); 接受头部迭代器
*it = 123;赋值123
it++; 指向下一个迭代器
*it = 124; 赋值124
obj.pop_front(); 头部元素弹出
obj.clear(); 清空该链表所有元素
print(obj.begin(), obj.end());
system("pause");
return 0;
}