【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()函数不会做任何事情。

相关推荐
澈2072 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
A.A呐2 小时前
【C++第二十九章】IO流
开发语言·c++
ambition202423 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
kebeiovo3 小时前
atomic原子操作实现无锁队列
服务器·c++
Yungoal3 小时前
常见 时间复杂度计算
c++·算法
6Hzlia3 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
Ricky_Theseus4 小时前
C++右值引用
java·开发语言·c++
吴梓穆5 小时前
UE5 c++ 常用方法
java·c++·ue5
云栖梦泽5 小时前
Linux内核与驱动:9.Linux 驱动 API 封装
linux·c++
Morwit5 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展