标签:扩容 1.5 int cap 编译器 vector ints 机制
一、扩容原理
Vector通过一个连续的数组存放元素,如果集合已满,在新增数据的时候,就要分配一块更大的内存,将原来的数据复制过来,释放之前的内存,在插入新增的元素。
二、扩容倍数
1.5倍或2倍(增长倍数太大会导致产生的堆空间浪费)
不同编译器扩容方式不同:
编译器 | 扩容倍数 |
---|---|
GCC | 2 |
MSVC | 1.5 |
CLANG | 1.5 |
测试代码:
#include <iostream>
#include <vector>
using namespace std;
int main(){
int cap = -1;
vector<int> ints;
for(int i = 0;i<1000000;i++){
ints.push_back(i);
if( cap != ints.capacity()){
cap = ints.capacity();
cout << " ints.size() = " << ints.size() << " ints.capacity() = " << cap << endl;
}
}
system("pause");
return 0;
}
测试结果:
GCC (1->2->4->8… 两倍)
MSVC (1->3->4->6… 1.5倍)
CLANG (1->3->4->6… 1.5倍)
标签:扩容,1.5,int,cap,编译器,vector,ints,机制 来源: https://blog.csdn.net/lial13/article/details/122634435
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。