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

相关推荐
feiduoge17 小时前
教程 44 - 相机系统
windows·游戏引擎·图形渲染
松涛和鸣18 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
gugugu.21 小时前
Redis ZSet类型深度解析:有序集合的原理与实战应用
网络·windows·redis
开开心心就好1 天前
免费卸载工具,可清理残留批量管理启动项
linux·运维·服务器·windows·随机森林·pdf·1024程序员节
xiaolang_8616_wjl1 天前
c++超级细致的基本框架
开发语言·数据结构·c++·算法
淼淼7631 天前
Qt调度 程序
开发语言·c++·windows·qt
LYFlied1 天前
【每日算法】LeetCode124. 二叉树中的最大路径和
数据结构·算法·leetcode·面试·职场和发展
Poetinthedusk1 天前
设计模式-命令模式
windows·设计模式·c#·wpf·命令模式
whm27771 天前
Visual Basic Data控件
windows·visual studio