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

相关推荐
陈葛杰7 小时前
Axure RP 10.0安装教程(傻瓜版)
windows·开源软件·axure
炸膛坦客9 小时前
嵌入式 - 数据结构与算法:(1-7)数据结构 - 顺序表和链表的对比
数据结构·链表
hoiii18710 小时前
基于栅格法的机器人工作空间划分系统
数据结构·机器人
我命由我1234512 小时前
Windows 操作系统 - Windows 查看架构类型
运维·windows·笔记·学习·系统架构·运维开发·系统
测绘第一深情15 小时前
在vscode中使用codex教程(个人安装经验)
数据结构·ide·vscode·python·算法·计算机视觉·编辑器
Byron Loong15 小时前
【逆向】Windows 三大注入:远程线程 、APC 、 钩子注入
windows
Liangwei Lin15 小时前
LeetCode 41. 缺失的第一个正数
数据结构·算法·leetcode
凤舞飘伶15 小时前
windows安装docker-desk
windows·docker·容器
绿豆人16 小时前
Cache缓存项目学习4
windows·学习·缓存
平行侠16 小时前
022Miller-Rabin 概率素性检验 - 概率与数论的完美联姻
数据结构·算法