【C++中resize和reserve的区别】

1. resize的用法

改变当前容器内含有元素的数量(size())比如:

cpp 复制代码
vector<int> vct;

int num = vct.size();//之前的元素个数为num
vct.resize(len);//现在的元素个数为len

如果num < len ,那么容器vct新增len - num个元素,元素的值默认为0;

若再对vct进行插入,如:

cpp 复制代码
vct.push_back(1);//此时将1插入到vct末尾,其下标就为len,容器的容量变为len +1

2. reserve的用法

改变当前容器的最大容量(capacity),不会生成元素,只是确认这个容器允许放入多少对象,如果reserve(len)的值大于当前的capacity(),那么会重新分配一块能存len个元素的空间,然后把之前的vct.size()个元素通过copy construtor复制过来,销毁之前的内存。

3. 代码实现

cpp 复制代码
#include<iostream>
#include<vector>
using namespace;

int mian(){
    vector<int> vct;
    
    vct.reserve(100);
    vct.resize(50);
    cout << vct.size() << " " << vct.capacity() << endl;//50 100
    
    vct.reserve(150);
    cout << vct.size() << " " << vct.capacity() << endl;//50 150

    vct.resize(100);
    cout << vct.size() << " " << vct.capacity() << endl;//100 150

    vct.reserve(50);
    cout << vct.size() << " " << vct.capacity() << endl;//100 150
    return 0;
}

发现在进行了vct.reserve(150)之后,再将reserve()参数设置为比150小的,不发生变化,说明如果新的容量比原来的容量小,reserve()函数不会做任何事情。

相关推荐
kyle~21 小时前
排序---堆排序(Heap Sort)
数据结构·c++·算法
王老师青少年编程21 小时前
线性DP第12课:线性DP应用案例实践:数字三角形
c++·动态规划·dp·线性dp·csp·信奥赛·数字三角形
汉克老师21 小时前
CCF-NOI2025第一试题目与解析(第二题、序列变换(sequence))
c++·算法·动态规划·noi
A charmer21 小时前
内存泄漏、死锁:定位排查工具+解决方案(C/C++ 实战指南)
c语言·开发语言·c++
程序员东岸21 小时前
《数据结构——排序(下)》分治与超越:快排、归并与计数排序的终极对决
数据结构·c++·经验分享·笔记·学习·算法·排序算法
无限进步_21 小时前
C++初始化列表详解:语法、规则与最佳实践
java·开发语言·数据库·c++·git·github·visual studio
想唱rap21 小时前
C++之红黑树
开发语言·数据结构·c++·算法
无限进步_21 小时前
C++运算符重载完全指南:从基础到实战应用
开发语言·数据库·c++·windows·git·github·visual studio
feiyangqingyun1 天前
Qt/C++地图最简示例/在线离线切换/地图视图切换/执行各种js函数交互
javascript·c++·qt
暗然而日章1 天前
C++基础:Stanford CS106L学习笔记 4 容器(STL与序列容器)
c++·笔记·学习