std::vector<T,Allocator>::shrink_to_fit
来自 cppreference.cn
void shrink_to_fit(); |
(constexpr since C++20) | |
请求移除未使用的容量。
这是一个非强制性的请求,将 capacity() 减少到 size()。请求是否被满足取决于具体实现。
如果重新分配发生,所有迭代器(包括 end()
迭代器)和所有元素的引用都将失效。如果未发生重新分配,则迭代器和引用均不会失效。
如果 |
(since C++11) |
目录 |
[编辑] 复杂度
最多与容器大小呈线性关系。
异常如果抛出异常,但不是由于非 CopyInsertable 的 |
(since C++11) |
[编辑] 注释
在 libstdc++ 中,shrink_to_fit()
在 C++98 模式下不可用。
[编辑] 示例
运行此代码
#include <iostream> #include <vector> int main() { std::vector<int> v; std::cout << "Default-constructed capacity is " << v.capacity() << '\n'; v.resize(100); std::cout << "Capacity of a 100-element vector is " << v.capacity() << '\n'; v.resize(50); std::cout << "Capacity after resize(50) is " << v.capacity() << '\n'; v.shrink_to_fit(); std::cout << "Capacity after shrink_to_fit() is " << v.capacity() << '\n'; v.clear(); std::cout << "Capacity after clear() is " << v.capacity() << '\n'; v.shrink_to_fit(); std::cout << "Capacity after shrink_to_fit() is " << v.capacity() << '\n'; for (int i = 1000; i < 1300; ++i) v.push_back(i); std::cout << "Capacity after adding 300 elements is " << v.capacity() << '\n'; v.shrink_to_fit(); std::cout << "Capacity after shrink_to_fit() is " << v.capacity() << '\n'; }
可能的输出
Default-constructed capacity is 0 Capacity of a 100-element vector is 100 Capacity after resize(50) is 100 Capacity after shrink_to_fit() is 50 Capacity after clear() is 50 Capacity after shrink_to_fit() is 0 Capacity after adding 300 elements is 512 Capacity after shrink_to_fit() is 300
[编辑] 缺陷报告
以下行为变更缺陷报告被追溯应用于之前发布的 C++ 标准。
DR | 应用于 | 已发布行为 | 正确行为 |
---|---|---|---|
LWG 755 | C++98 | std::vector 缺少显式的 shrink-to-fit 操作 |
已提供 |
LWG 2033 | C++98 C++11 |
1. 缺少复杂度要求 (C++98) 2. T 不需要是 MoveInsertable (C++11) |
1. 已添加 2. 已要求 |
LWG 2223 | C++98 C++11 |
1. 引用、指针和迭代器不会失效 (C++98) 2. 没有异常安全保证 (C++11) |
1. 它们可能会失效 2. 已添加 |
[编辑] 参见
返回元素数量 (公共成员函数) | |
返回当前已分配存储空间中可以容纳的元素数量 (公共成员函数) |