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

相关推荐
漫随流水6 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
One_Blanks7 小时前
WIndows x64 ShellCode开发 第三章 x64汇编细节点
汇编·windows·网络安全·渗透测试·红队技术
C++ 老炮儿的技术栈7 小时前
分享一个安全的CString
c语言·c++·windows·git·安全·visual studio
淼淼爱喝水8 小时前
openEuler 下 Ansible 基础命令详解与实操演示2
linux·运维·windows
One_Blanks8 小时前
WIndows ShellCode开发 第四章 动态API调用
windows·网络安全·渗透测试
idolao8 小时前
RStudio 2025 + R 4.5.0 安装与配置教程 Windows版:解压+双软件安装+自定义路径+R语言关联指南
windows
Leo655359 小时前
动态透视报表 + 查询接口 + Excel导出
开发语言·windows·python
Titan20249 小时前
map和set的封装学习笔记
数据结构·c++
Yupureki10 小时前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划
算法鑫探11 小时前
C语言实战:学生成绩统计与分析
c语言·数据结构·算法·新人首发