resize改变容器中元素的数量,涉及构造或销毁;reserve仅预分配内存,不改变元素数量,用于优化性能避免频繁重分配。

C++ STL容器中的
resize
reserve
resize
reserve
理解
resize
reserve
std::vector::reserve(size_type new_cap)
reserve
capacity()
new_cap
立即学习“C++免费学习笔记(深入)”;
new_cap
capacity()
new_cap
capacity()
reserve
size()
capacity()
reserve
size()
capacity()
reserve
push_back
示例:
std::vector<int> vec;
std::cout << "初始: size=" << vec.size() << ", capacity=" << vec.capacity() << std::endl;
// 输出: 初始: size=0, capacity=0 (或某个小值)
vec.reserve(10);
std::cout << "reserve(10)后: size=" << vec.size() << ", capacity=" << vec.capacity() << std::endl;
// 输出: reserve(10)后: size=0, capacity=10 (或更大)
for (int i = 0; i < 5; ++i) {
vec.push_back(i);
}
std::cout << "push_back 5个元素后: size=" << vec.size() << ", capacity=" << vec.capacity() << std::endl;
// 输出: push_back 5个元素后: size=5, capacity=10std::vector::resize(size_type count)
std::vector::resize(size_type count, const T& value)
resize
size()
count
size()
size()
count
value
value
capacity()
count
count
size()
size()
count
size()
capacity()
size()
count
capacity()
shrink_to_fit()
resize
示例:
std::vector<int> vec;
vec.resize(5); // 容器现在有5个元素,都是默认初始化的0
std::cout << "resize(5)后: size=" << vec.size() << ", capacity=" << vec.capacity() << std::endl;
// 输出: resize(5)后: size=5, capacity=5 (或更大)
for (int x : vec) {
std::cout << x << " "; // 输出: 0 0 0 0 0
}
std::cout << std::endl;
vec.resize(3); // 容器现在有3个元素,最后两个被销毁
std::cout << "resize(3)后: size=" << vec.size() << ", capacity=" << vec.capacity() << std::endl;
// 输出: resize(3)后: size=3, capacity=5 (或更大)
for (int x : vec) {
std::cout << x << " "; // 输出: 0 0 0
}
std::cout << std::endl;
vec.resize(7, 99); // 容器现在有7个元素,新增的4个是99
std::cout << "resize(7, 99)后: size=" << vec.size() << ", capacity=" << vec.capacity() << std::endl;
// 输出: resize(7, 99)后: size=7, capacity=7 (或更大)
for (int x : vec) {
std::cout << x << " "; // 输出: 0 0 0 99 99 99 99
}
std::cout << std::endl;reserve
我个人经验里,
reserve
std::vector
push_back
emplace_back
reserve
想象一下,你有一个循环,需要向
std::vector
reserve
vector
capacity
vector
这些操作,特别是复制/移动元素,开销非常大。对于10000个元素,你可能会经历十几次甚至更多的重新分配。每一次都意味着大量的数据移动。而一旦你调用了
vec.reserve(10000)
vector
push_back
我通常会这样思考:如果你有一个函数,它的任务是收集数据并返回一个
vector
reserve
reserve
resize
reserve
使用这两个函数,如果理解不深,确实会踩到一些坑。
reserve
reserve
reserve(1000000)
push_back
vector
shrink_to_fit()
size()
reserve(N)
vec[i]
i < N
reserve
capacity()
size()
vec[0]
reserve
push_back
emplace_back
resize
resize
resize
resize
resize
resize(count)
int
double
resize(count, value)
resize
size()
vector
resize
总的来说,关键在于理解
size
capacity
resize
reserve
是的,
resize
reserve
组合使用的场景和最佳实践:
最常见的组合模式是:先reserve
push_back
emplace_back
resize
预知最大容量,逐步填充: 如果你知道容器可能达到的最大元素数量(或一个合理的上限),但实际填充的元素数量可能不确定,或者需要通过循环逐个添加,那么先
reserve
std::vector<MyObject> objects;
objects.reserve(1000); // 预留1000个MyObject的内存空间
// 假设通过某个循环或算法添加元素
for (int i = 0; i < some_dynamic_count; ++i) {
if (condition_met) {
objects.push_back(MyObject(i)); // 高效添加,避免重新分配
}
}
// 此时 objects.size() 可能小于等于 1000这种模式下,
reserve
push_back
size()
需要精确数量的占位符,并可能后续修改: 如果你需要一个容器,一开始就包含特定数量的元素(作为占位符),并且这些元素可能在后续被修改,那么直接使用
resize
std::vector<int> scores; scores.resize(5, 0); // 创建一个包含5个0的vector,作为初始分数 // 后续可以修改这些分数 scores[0] = 95; scores[4] = 88;
这种情况下,
resize
预留容量并填充,然后截断或扩展: 这是一种更复杂的组合,它结合了前两者的优点。
std::vector<double> data_points;
data_points.reserve(200); // 预计最多有200个数据点
// 收集数据,通过 push_back 添加
for (int i = 0; i < 150; ++i) { // 假设实际只收集了150个
data_points.push_back(static_cast<double>(i) * 1.5);
}
// 此时 data_points.size() 是 150,capacity 至少是 200。
// 如果现在需要确保容器正好有 180 个元素,多余的用 0.0 填充
data_points.resize(180, 0.0);
// 现在 data_points.size() 是 180,capacity 至少是 200。
// 如果需要减少到 100 个元素
data_points.resize(100); // 后面的80个元素被销毁我通常是这样用:如果我能大致估算出最终的元素数量,我会先
reserve
resize
总结最佳实践:
reserve
push_back
emplace_back
reserve
resize
resize
reserve
capacity()
size()
resize
size()
capacity()
理解这两种操作的内在机制和应用场景,是写出高效、健出C++代码的基础。
以上就是C++STL容器resize和reserve使用方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号