• vector.clear()不能用来清零


    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;
    }
  • 相关阅读:
    CUDA并行算法系列之FFT快速卷积
    CUDA并行算法系列之规约
    混合语言编程:启用CLR(公共语言运行时编译)让C#调用C++
    【CUDA并行程序设计系列(4)】CUDA内存
    【CUDA并行程序设计系列(3)】CUDA线程模型
    【CUDA并行程序设计系列(2)】CUDA简介及CUDA初步编程
    【CUDA并行程序设计系列(1)】GPU技术简介
    关于CUDA的一些学习资料
    MacOS 快捷键技巧
    chrom 自带截屏用法
  • 原文地址:https://www.cnblogs.com/chenjx85/p/9662535.html
Copyright © 2020-2023  润新知