命名空间
变体
操作

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

来自 cppreference.cn
< cpp‎ | container‎ | vector
 
 
 
 
void shrink_to_fit();
(constexpr since C++20)

请求移除未使用的容量。

这是一个非强制性的请求,将 capacity() 减少到 size()。请求是否被满足取决于具体实现。

如果重新分配发生,所有迭代器(包括 end() 迭代器)和所有元素的引用都将失效。如果未发生重新分配,则迭代器和引用均不会失效。

如果 T 不是 MoveInsertablestd::vector<T, Allocator> 中,则行为是未定义的。

(since C++11)

目录

[编辑] 复杂度

最多与容器大小呈线性关系。

异常

如果抛出异常,但不是由于非 CopyInsertableT 的移动构造函数抛出的,则不会有任何影响。

(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. 已添加

[编辑] 参见

返回元素数量
(公共成员函数) [编辑]
返回当前已分配存储空间中可以容纳的元素数量
(公共成员函数) [编辑]