c++:list简介和常见用法总结
一:定义
1.list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。 2.list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向其前一个元素和后一个元素。 3.list 与forward_list非常相似:主要的不同在于forword_list是单链表,只能朝前迭代。 与其他的序列是容器相比(array,vector,deque)list 通常在任意位置进行插入、移除元素的效率更高。 4.与其他序列是容器相比,list 和 forward_list最大的缺陷是不支持任意位置的随机访问,比如:要访问list 的第6个元素,必须从已知位置(比如头部或者尾部)迭代到该位置,在这段位置上迭代需要线性的时间开销;list 还需要一些额外的空间,以保存每个结点的相关信息。
好吧,可能看着有点蒙,那么我们直接看使用就好
二:函数声明
#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
#include<list>
using namespace std;
int main()
{
list<int> ls1;//单纯的构建一个list
list<int> ls2(3,9);//构造一个包含3个9的list
list<int> ls3(ls2.begin(), ls2.end());//构造一个以list2开始list2结束的list3,也就是范围
list<int> ls4(ls3);//拷贝构造
//这下面是打印的函数
for (auto e : ls1)
{
cout << e << " ";
}
cout <<"这是list1" << endl;
for (auto e : ls2)
{
cout << e << " ";
}
cout <<"这是ilst2" << endl;
for (auto e : ls3)
{
cout << e << " ";
}
cout << "这是list3" << endl;
for (auto e : ls4)
{
cout << e << " ";
}
cout << "这是list4" << endl;
return 0;
}
结果如下:
三:list的迭代器iterator
这里直接将iterator理解成指针就好
int main()
{
list<int> ls(10, 9);
list<int>::iterator it = ls.begin();//it指向了ls的首地址
while (it != ls.end())//如果it不等于ls的最后一个
{
cout << *it << " ";//解引用
it++;
}
cout << endl;
return 0;
}
结果如下:
四:list的迭代器失效
list本身是一个双向循环链表
如果我们要在插入一个数,那么就开一个新空间,但是it不会失效
但是如果我们删除这个结点,那么it指向的空间就被释放,那么it也就变成了野指针了,这个时候我们就需要给it赋值
while (it != l.end)
{
//这是错误的:
//l.erase(it);
//++it;
//erase()函数执行以后,it所指向的节点已经被删除,因此it无效,在下一次使用it时,必须先给其赋值
//这是正确的:
it = l.erase(it);
}
上一篇:
JS实现多线程数据分片下载
下一篇:
在两个kafka集群同步topic
