std::vector<T,Allocator>::shrink_to_fit
來自 cppreference.com
void shrink_to_fit(); |
(C++20 起為 constexpr) | |
請求移除未使用的容量。
這是一個非強制性的請求,要求將 capacity() 減小到 size()。該請求是否被實現取決於具體實現。
如果發生重新分配,所有迭代器(包括 end()
迭代器)以及所有元素引用都將失效。如果未發生重新分配,則沒有迭代器或引用失效。
如果 |
(C++11 起) |
目錄 |
[編輯] 複雜度
最多與容器大小呈線性關係。
異常如果丟擲異常,而不是由非 可複製插入 |
(C++11 起) |
[編輯] 注意
在 libstdc++ 中,C++98 模式下不可用 shrink_to_fit()
。
[編輯] 示例
執行此程式碼
#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++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 755 | C++98 | std::vector 缺少顯式的 shrink-to-fit 操作 |
已提供 |
LWG 2033 | C++98 C++11 |
1. 缺少複雜度要求 (C++98) 2. T 不需要是 可移動插入 的 (C++11) |
1. 新增 2. 要求 |
LWG 2223 | C++98 C++11 |
1. 引用、指標和迭代器未失效 (C++98) 2. 沒有異常安全保證 (C++11) |
1. 它們可能失效 2. 新增 |
[編輯] 參閱
返回元素數量 (公共成員函式) | |
返回當前已分配儲存空間中可容納的元素數量 (公共成員函式) |