百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

vector size() 和 capacity() 的区别

liuian 2025-01-14 15:19 34 浏览

std::vector 是动态数组,存储的数据在内存上是连续的。

那size 和 capacity 有什么区别呢?虽然看起来很简单,但是不细想一下还是会混淆的。

看个例子就能理解了:

#include <iostream>
#include <iterator>
#include <vector>

void PrintVector(const std::vector<int> &a) {
  std::cout << "\n==== size:" << a.size() << " capacity:" << a.capacity()
            << " ====" << std::endl;
  for (auto p : a) {
    std::cout << p << "\t";
  }
  std::cout << std::endl;
}
int main() {
  std::vector<int> a(3, 3); // size 3 capacity 3
  a.reserve(4); // 元素没有变化因此 size 3 容量提高了 因此 capacity 4
  PrintVector(a);
  a = {1, 2, 3}; // 元素改变因此size 3 原来的容量4足够存储了因此不变 capacity 4
  PrintVector(a);
  a.resize(10, 20); // 元素改变size10 多出来的元素20填充capacity需要提升为10
  PrintVector(a);
  a.resize(5, 30); // 元素减少 因此size 5 多出来的元素直接删除 capacity不变
  PrintVector(a);
  a.reserve(50); // 元素没有变化 因此size 5 capacity 50
  PrintVector(a);
  a.reserve(5); // 元素没有变化 因此size 5 capacity 已经大于5了  因此不变
  PrintVector(a);
  return 0;
}

// ================================================
==== size:3 capacity:4 ====
3       3       3

==== size:3 capacity:4 ====
1       2       3

==== size:10 capacity:10 ====
1       2       3       20      20      20      20      20      20      20

==== size:5 capacity:10 ====
1       2       3       20      20

==== size:5 capacity:50 ====
1       2       3       20      20

==== size:5 capacity:50 ====
1       2       3       20      20


这里是不是发现为什么没有两倍扩容呢?

下面这个例子就会触发两倍扩容,原因是push_back 和 赋值操作(=)是不一样的,push_back 会在原有的内存上不断增加数据,直到超过容量了,重新分配一块新的内存块,而赋值操作则是每次都需要擦除原有数据,capacity 和 size 会保持一致。

#include <iostream>
#include <vector>

int main() {
  std::vector<int> vec;

  std::cout << "Initial size: " << vec.size()
            << ", capacity: " << vec.capacity() << std::endl;

  // 插入元素并观察容量变化
  for (int i = 0; i < 20; ++i) {
    vec.push_back(i);
    std::cout << "After inserting element " << i << ": size = " << vec.size()
              << ", capacity = " << vec.capacity() << std::endl;
  }

  return 0;
}
// ================================================
Initial size: 0, capacity: 0
After inserting element 0: size = 1, capacity = 1
After inserting element 1: size = 2, capacity = 2
After inserting element 2: size = 3, capacity = 4
After inserting element 3: size = 4, capacity = 4
After inserting element 4: size = 5, capacity = 8
After inserting element 5: size = 6, capacity = 8
After inserting element 6: size = 7, capacity = 8
After inserting element 7: size = 8, capacity = 8
After inserting element 8: size = 9, capacity = 16
After inserting element 9: size = 10, capacity = 16
After inserting element 10: size = 11, capacity = 16
After inserting element 11: size = 12, capacity = 16
After inserting element 12: size = 13, capacity = 16
After inserting element 13: size = 14, capacity = 16
After inserting element 14: size = 15, capacity = 16
After inserting element 15: size = 16, capacity = 16
After inserting element 16: size = 17, capacity = 32
After inserting element 17: size = 18, capacity = 32
After inserting element 18: size = 19, capacity = 32
After inserting element 19: size = 20, capacity = 32


总结:

--1 size 是元素个数 capacity 是容量大小

--2 size 随着元素个数变化实时变化 capacity 只有当容量不足的时候才会重新分配

--3 push_back 会触发两倍扩容 而 = 赋值运算并不会

相关推荐

打开新世界,教你用RooCode+Copliot+Mcp打造一个自己的Manus

本文耗时两天打造,想要一遍走通需要花点时间,建议找个专注的时间开搞!这不仅是个免费使用claude3.5的方案,也是一个超级智能体方案,绝对值得一试!最近Manus真是赚足了眼球,然而我还是没有邀请码...

Git仓库(git仓库有哪些)

#Git仓库使用方法流程详解##一、环境搭建与基础配置###1.1安装与初始化-**安装Git**:官网下载安装包,默认配置安装-**配置全局信息**:```bashgitconfig...

idea版的cursor:Windsurf Wave 7(ideawalk)

在企业环境中,VisualStudioCode和JetBrains系列是最常用的开发工具,覆盖了全球绝大多数开发者。这两类IDE各有优势,但JetBrains系列凭借其针对特定语言和企业场景的深度...

Ai 编辑器 Cursor 零基础教程:推箱子小游戏实战演练

最近Ai火的同时,Ai编辑器Cursor同样火了一把。今天我们就白漂一下Cursor,使用免费版本搞一个零基础教程,并实战演练一个“网页版的推箱子小游戏”。通过这篇文章,让你真正了解cursor是什么...

ChatGPT深度集成于苹果Mac软件 编码能力得到提升

【CNMO科技消息】近日,OpenAI发布了针对MacOS的桌面应用程序,并宣布了一系列与各类应用程序的互操作性功能,标志着ChatGPT正在从聊天机器人向AI智能体工具进化。此次发布的MacOS桌面...

日常开发中常用的git操作命令和使用技巧

日常开发中常用的git操作命令,从配置、初始化本地仓库到提交代码的常用git操作命令使用git前的配置刚使用git,先要在电脑上安装好git,接着我们需要配置一下帐户信息:用户名和邮箱。#设置用户名...

Trae IDE 如何与 GitHub 无缝对接?

TraeIDE内置了GitHub集成功能,让开发者可以直接在IDE里管理代码仓库和版本控制。1.直接从GitHub克隆项目如果你想把GitHub上的代码拉到本地,Trae提供了...

China&#39;s diplomacy to further provide strong support for country&#39;s modernization: FM

BEIJING,March7(Xinhua)--ChineseForeignMinisterWangYisaidFridaythatChina'sdiplomacywil...

三十分钟入门基础Go(Java小子版)(java入门级教程)

前言Go语言定义Go(又称Golang)是Google的RobertGriesemer,RobPike及KenThompson开发的一种静态、强类型、编译型语言。Go语言语法与...

China will definitely take countermeasures in response to arbitrary pressure: FM

BEIJING,March7(Xinhua)--Chinawilldefinitelytakecountermeasuresinresponsetoarbitrarypre...

Go操作etcd(go操作docker实现沙箱)

Go语言操作etcd,这里推荐官方包etcd/clientv3。文档:https://pkg.go.dev/go.etcd.io/etcd/clientv3etcdv3使用gRPC进行远程过程调...

腾讯 Go 性能优化实战(腾讯游戏优化软件)

作者:trumanyan,腾讯CSIG后台开发工程师项目背景网关服务作为统一接入服务,是大部分服务的统一入口。为了避免成功瓶颈,需要对其进行尽可能地优化。因此,特别总结一下golang后台服务...

golang 之JWT实现(golang gin jwt)

什么是JSONWebToken?JSONWebToken(JWT)是一个开放标准(RFC7519),它定义了一种紧凑且自包含的方式,用于在各方之间以JSON方式安全地传输信息。由于此信息是经...

一文看懂 session 和 cookie(session cookie的区别)

-----------cookie大家应该都熟悉,比如说登录某些网站一段时间后,就要求你重新登录;再比如有的同学很喜欢玩爬虫技术,有时候网站就是可以拦截住你的爬虫,这些都和cookie有关。如果...

有望取代 java?GO 语言项目了解一下

GO语言在编程界一直让人又爱又恨,有人说“GO将统治下一个十年”,“几乎所有新的、有趣的东西都是用Go写的”;也有人说它过于死板,使用感太差。国外有Google、AWS、Cloudflar...