卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章76004本站已运行4317

C++ 自身函数详解及应用:vector 容器如何动态管理内存?

vector 容器通过指针和动态内存分配来管理内存,在需要时分配或释放内存,并在添加或删除元素时相应调整缓冲区的大小,实现动态管理内存的功能。其主要函数包括:vector() 创建空 vector,vector() 创建指定元素个数的 vector,vector() 从指定范围创建 vector,push_back() 新增元素,pop_back() 移除末尾元素,begin() 返回第一个元素迭代器,end() 返回指向最后一个元素之后元素的迭代器,size() 返回元素个数,max_size() 返回最大元素个数。

C++ 自身函数详解及应用:vector 容器如何动态管理内存?

C++ 自身函数详解及应用:vector 容器如何动态管理内存?

前言

vector 是 C++ 标准库中一种常用的动态数组容器,它允许我们在运行时轻松地添加和删除元素。其动态管理内存的能力使其成为存储和处理大数据集的理想选择。

立即学习“C++免费学习笔记(深入)”;

点击下载“修复打印机驱动工具”;

vector 函数详细说明

vector 容器提供了以下主要函数:

  • vector():创建一个空的 vector。
  • vector(size_t n):创建一个包含 n 个默认构造元素的 vector。
  • vector(size_t n, const T& value):创建一个包含 n 个指定值元素的 vector。
  • vector(InputIterator first, InputIterator last):从指定范围创建 vector。
  • push_back(const T& value):在 vector 末尾新增一个元素。
  • pop_back():移除并销毁 vector 末尾的元素。
  • begin():返回指向 vector 中第一个元素的迭代器。
  • end():返回指向 vector 中最后一个元素之后的元素的迭代器。
  • size():返回 vector 中元素的 count。
  • max_size():返回 vector 可以容纳的最大元素 count。

动态内存管理

vector 容器通过使用指针和动态内存分配来管理内存。它创建一个内部数组(通常称为缓冲区),并在需要时分配或释放额外的内存。

当使用 push_back() 函数添加新元素时,vector 会检查其当前容量并相应地调整缓冲区的大小。如果缓冲区已满,它会分配一个更大的缓冲区并移动现有元素。相反,当使用 pop_back() 函数移除元素时,vector 会缩小缓冲区并释放多余的内存。

实战案例

以下代码演示了如何在 C++ 中使用 vector 容器:

#include <iostream>
#include <vector>

int main() {
  // 创建并初始化一个 vector
  std::vector<int> numbers = {1, 3, 5, 7, 9};

  // 遍历并打印 vector 中的元素
  for (int num : numbers) {
    std::cout << num << " ";
  }
  std::cout << std::endl;

  // 添加一个新元素
  numbers.push_back(11);

  // 获取元素的 count
  std::cout << "Size of the vector: " << numbers.size() << std::endl;

  // 移除最后一个元素
  numbers.pop_back();

  // 再次打印 vector 中的元素
  for (int num : numbers) {
    std::cout << num << " ";
  }
  std::cout << std::endl;

  return 0;
}
卓越飞翔博客
上一篇: C++ lambda 表达式在设计模式中的运用
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏