【std::vector】resize元素处理方式

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


你想弄清楚这段C++代码中,vector执行resize(5)后原10个元素里后5个的处理方式,以及resize(7)新增的两个元素的值,同时理解sizecapacity的变化,我会准确解答这些问题。

核心原理与代码验证

首先给出完整可运行的代码(补全头文件),并展示输出结果,再分步解释关键逻辑:

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

int main() {
    vector<int>v(10, 5);  // 初始化:10个元素,每个值为5
    cout << v.size() << "  " << v.capacity() << endl;
    for (int i : v) {
        cout << i << "  ";
    }
    cout << endl;
    
    v.resize(5);  // 缩小size到5
    cout << v.size() << "  " << v.capacity() << endl;
    for (int i : v) {
        cout << i << "  ";
    }
    cout << endl;
    
    v.resize(7);  // 扩大size到7
    cout << v.size() << "  " << v.capacity() << endl;
    for (int i : v) {
        cout << i << "  ";
    }
    cout << endl;

    return 0;
}

输出结果

复制代码
10  10
5  5  5  5  5  5  5  5  5  5  
5  10
5  5  5  5  5  
7  10
5  5  5  5  5  0  0  

分步解释关键问题

1. v.resize(5) 对后5个元素的处理

resize(n) 的核心作用是调整vector有效元素个数(size),而非释放内存(capacity):

  • n < 当前size 时:vector销毁 索引从nsize()-1的元素(这里是索引5~9的5个元素),这些元素不再属于vector的"有效元素范围",访问它们属于未定义行为(不能假设它们保持5或被清零)。
  • capacity 保持不变(仍为10):vector 为了效率,不会主动释放已分配的内存(缩容需要手动触发,比如shrink_to_fit())。
  • 最终有效元素仅保留前5个,值仍为5。
2. v.resize(7) 新增元素的值

n > 当前size 时:vector 会在末尾新增n - 当前size个元素(这里是2个):

  • resize未指定新元素的初始值,新增元素会用元素类型的默认值初始化
    • int 类型的默认值是0,因此新增的2个元素(索引5、6)的值是0,而非原来的5(原后5个元素已被销毁,内存空间虽未释放,但已不属于有效元素)。
  • capacity 仍为10:新增元素未超出已分配的内存范围,无需扩容。

总结

  1. resize(5):销毁后5个元素(索引5~9),size变为5,capacity仍为10,有效元素仅前5个5。
  2. resize(7):新增2个元素,用int默认值0初始化(非原5),size变为7,capacity仍为10。
  3. vectorcapacity仅在新增元素超出当前容量时扩容,resize不会主动缩容/扩容(仅调整有效元素数)。
相关推荐
仰泳的熊猫3 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
Thera7777 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
君义_noip8 小时前
信息学奥赛一本通 1952:【10NOIP普及组】三国游戏 | 洛谷 P1199 [NOIP 2010 普及组] 三国游戏
c++·信息学奥赛·csp-s
旖-旎9 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
顶点多余9 小时前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
汉克老师9 小时前
GESP2026年3月认证C++四级( 第二部分判断题(1-10))
c++·指针·函数重载·文件操作·数组·gesp4级·gesp四级
khddvbe10 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
wWYy.10 小时前
STL:list
开发语言·c++
小比特_蓝光11 小时前
vector模拟实现
c++
咱就是说不配啊11 小时前
3.19打卡day33
数据结构·c++·算法