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; }