名稱空間
變體
操作

std::vector<T,Allocator>::shrink_to_fit

來自 cppreference.com
< cpp‎ | 容器‎ | vector
 
 
 
 
void shrink_to_fit();
(C++20 起為 constexpr)

請求移除未使用的容量。

這是一個非強制性的請求,要求將 capacity() 減小到 size()。該請求是否被實現取決於具體實現。

如果發生重新分配,所有迭代器(包括 end() 迭代器)以及所有元素引用都將失效。如果未發生重新分配,則沒有迭代器或引用失效。

如果 T 不能 可移動插入std::vector<T, Allocator> 中,則行為是未定義的。

(C++11 起)

目錄

[編輯] 複雜度

最多與容器大小呈線性關係。

異常

如果丟擲異常,而不是由非 可複製插入 T 的移動建構函式丟擲,則無任何影響。

(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. 新增

[編輯] 參閱

返回元素數量
(公共成員函式) [編輯]
返回當前已分配儲存空間中可容納的元素數量
(公共成員函式) [編輯]