vector.clear()函数并不会把所有元素清零,笔者就曾经这样幻想过这个函数的作用,然而事实证明并不是。
vector有两个参数,一个是size,表示当前vector容器内存储的元素个数,一个是capacity,表示当前vector在内存中申请的这片区域所能容纳的元素个数。
通常capacity会比size大,如果往vector中push_back数据,这样就不用重新申请内存和拷贝元素到新内存区域了,便于节省时间。
所以vector.clear()的真正作用是:把size设置成0,capacity不变。
测试代码如下:
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<vector<int>>res(12,vector<int>(12,0));//12行12列的vector
int count=1;
for(int i=0;i<12;i++)//给vector赋值,递增赋值
{
for(int j=0;j<12;j++)
{
res[i][j]=count;
count++;
}
}
cout<<res.size()<<res.capacity()<<endl;//这时候输出12和12
res.clear();//清空res
cout<<res.size()<<res.capacity()<<endl;//这时候输出0和12,也就是说size设置为0,capacity不变。
for(int i=0;i<12;i++)//这时候输出res的内容,会发现前五个数字是一些杂乱无章的数字,后面就还好
{
for(int j=0;j<12;j++)
{
cout<<res[i][j]<<" ";
}
cout<<endl;
}
return 0;
}
clear()的真正作用是改变size,capacity保持不变,不知道这块区域有没有在clear之后释放给内存去使用。
如果想要清零vector的话,还是得重新定义一个vector,或者用assign函数,示范代码如下:
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<vector<int>>res(12,vector<int>(12,0));
int count=1;
for(int i=0;i<12;i++)//同样递增赋值
{
for(int j=0;j<12;j++)
{
res[i][j]=count;
count++;
}
}
cout<<res.size()<<res.capacity()<<endl;
res.assign(12,vector<int>(12,0));//assign先删除掉res中的所有元素,接着插入12个vector<int>(12,0),时间花费还是大了点
//res=vector<vector<int>>(12,0);//或者直接定义一个新的,赋给res。
for(auto i:res)
{
for(int j:i)
{
cout<<j<<" ";
}
cout<<endl;
}
return 0;
}