vector容器原理是什么?
一、vector容器原理
vector容器分配的是一块连续的内存空间,每次容器的增长,并不是在原有连续的内存空间后再进行简单的叠加,而是重新申请一块更大的新内存,并把现有容器中的元素逐个复制过去,然后销毁旧的内存。
vector是STL中最常见的容器,它是一种顺序容器,支持随机访问。vector是一块连续分配的内存,从数据安排的角度来讲,和数组极其相似,不同的地方就是:数组是静态分配空间,一旦分配了空间的大小,就不可再改变了;而vector是动态分配空间,随着元素的不断插入,它会按照自身 的一套机制不断扩充自身的容量。vector是为了实现动态数组而产生的容器,然而向量这个名字是STL编写者取名没区好,因为在数学上的向量在几何中是矢量,两者名字相同而意义大相径庭。
延伸阅读:
二、vector 容量和大小
顾名思义,size表示当前有多少个元素,capacity是可容纳的大小。因为vector是顺序存储的,那么和数组一样,有一个初始容量,在vector里就是capacity。capacity必然大于等于size,每次扩容时会改变,具体大小和vector底层实现机制有关。
max_size是可存储的最大容量,和实际的编译器、系统有关,使用的比较少。
empty很好理解,判断vector是否为空,其实就是判断size是否等于0。定义vector时设定了大小、resize修改大小等操作,vector都不为空;clear后,size=0,那么empty判断就为空。
resize改变size的大小,而reserve改变capacity的大小,shrink_to_fit减小capacity到size。
相关推荐HOT
更多>>vector容器原理是什么?
一、vector容器原理vector容器分配的是一块连续的内存空间,每次容器的增长,并不是在原有连续的内存空间后再进行简单的叠加,而是重新申请一块...详情>>
2023-10-20 18:14:35单调栈什么时候从后向前遍历,什么时候从前向后遍历?
一、单调栈什么时候从后向前遍历,什么时候从前向后遍历如果是求右边的名列前茅个最大,那么就是从右向左遍历,构建单调递增栈。如果是求右边的...详情>>
2023-10-20 14:41:19HashMap为什么不用B+树来替换红黑树?
一、HashMap不用B+树来替换红黑树的原因1、算法实现复杂Java中已经实现了红黑树,而B+树的实现还需要从头开始,复杂度会更高。2、底层不符合Has...详情>>
2023-10-20 14:08:41数据结构的主要内容有哪些?
一、基本概念和术语1.数据数据是描述客观事物的符号,是计算机可以操作的对象,是能被计算机识别,并输入到计算机处理的符号集合。(数据不仅仅...详情>>
2023-10-20 13:16:16