【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不会主动缩容/扩容(仅调整有效元素数)。
相关推荐
Qt程序员10 小时前
Linux RCU 原理与应用
linux·c++·内核·linux内核·rcu
qeen8710 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习
王老师青少年编程11 小时前
信奥赛C++提高组csp-s之搜索进阶(记忆化搜索案例实践3)
c++·记忆化搜索·方格取数·csp·信奥赛·csp-s·提高组
Titan202412 小时前
Linux动静态库
linux·服务器·c++
j_xxx404_13 小时前
MySQL表操作硬核解析:从 CREATE TABLE 到磁盘文件、ALTER TABLE 与 DDL 风险
运维·服务器·数据库·c++·mysql·adb·ai
wuminyu13 小时前
Java锁机制之park和unpark源码剖析
java·linux·c语言·jvm·c++
玖玥拾14 小时前
C/C++ 基础笔记(十一)类的进阶
c语言·c++·设计模式·
-森屿安年-14 小时前
1137. 第 N 个泰波那契数
c++·动态规划
程序员老舅15 小时前
从内核视角,看Linux文件读写过程
linux·服务器·c++·内核·linux内核·vfs·linux内存
Soari15 小时前
llama.cpp更新(b9553):LLM inference in C/C++,本地和云端实现高性能大模型推理
c语言·c++·llama