vector 容器通过指针和动态内存分配来管理内存,在需要时分配或释放内存,并在添加或删除元素时相应调整缓冲区的大小,实现动态管理内存的功能。其主要函数包括:vector() 创建空 vector,vector() 创建指定元素个数的 vector,vector() 从指定范围创建 vector,push_back() 新增元素,pop_back() 移除末尾元素,begin() 返回第一个元素迭代器,end() 返回指向最后一个元素之后元素的迭代器,size() 返回元素个数,max_size() 返回最大元素个数。
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++ 自身函数详解及应用:vector 容器如何动态管理内存?的详细内容,更多请关注本网内其它相关文章!