list和vector的区别

1>list可以按值删除

vector和deque没有给定的函数,需要find();和erase();一起使用才能做到

2>list删除元素会释放空间,vector不会

3>list是双向迭代器,vector是随机迭代器

4>list内部排序是指针指向的更改,vector涉及对象的创建和销毁

5>vector改变元素,导致迭代器失效

deque删除的时候不会导致迭代器失效(非迭代器位置),插入会导致迭代器失效

list删除元素导致当前迭代器失效,不影响其他迭代器

6>vector是连续存储容器,动态数组

list是动态双向链表

7>vector连续空间,不容易产生内部碎片

list节点不连续,容易造成内部碎片,空间利用率低

8>vector访问具有局部性,存放高速缓存

list存放内存

相关推荐
sin_hielo16 分钟前
leetcode 2211
数据结构·算法·leetcode
Queenie_Charlie18 分钟前
和为k的连续区间
数据结构·c++·map
爱学java的ptt1 小时前
206反转链表
数据结构·链表
java修仙传1 小时前
力扣hot100:最大子数组和
数据结构·算法·leetcode
hweiyu001 小时前
数据结构:二叉树
数据结构
Rock_yzh1 小时前
LeetCode算法刷题——54. 螺旋矩阵
数据结构·c++·学习·算法·leetcode·职场和发展·矩阵
ベadvance courageouslyミ1 小时前
数据结构(一)
数据结构
lightqjx2 小时前
【C++】对set和map的使用
开发语言·数据结构·c++·stl
wuletaotao2 小时前
Windows 下 Redis 使用完整教程
数据库·windows·redis
AI科技星2 小时前
时空运动的几何约束:张祥前统一场论中圆柱螺旋运动光速不变性的严格数学证明与物理诠释
服务器·数据结构·人工智能·python·科技·算法·生活