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存放内存

相关推荐
王老邪31 分钟前
Windows下利用PowerShell实现Git自动推送
windows·git
短剑重铸之日38 分钟前
《7天学会Redis》Day2 - 深入Redis数据结构与底层实现
数据结构·数据库·redis·后端
执携3 小时前
算法 -- 冒泡排序
数据结构·算法
wen__xvn4 小时前
代码随想录算法训练营DAY14第六章 二叉树 part02
数据结构·算法·leetcode
Ka1Yan4 小时前
[数组] - 代码随想录(2-6)
数据结构·算法·leetcode
漫随流水5 小时前
leetcode算法(104.二叉树的最大深度)
数据结构·算法·leetcode·二叉树
执携7 小时前
数据结构 -- 数组(Array)
数据结构
洛豳枭薰7 小时前
List梳理
数据结构·windows·list
东木月7 小时前
使用python获取Windows产品标签
开发语言·windows·python
星火开发设计7 小时前
C++ multiset 全面解析与实战指南
开发语言·数据结构·c++·学习·set·知识