std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::max_size
来自 cppreference.com
size_type max_size() const noexcept; |
(自 C++11 起) | |
返回容器由于系统或库实现限制能够容纳的最大元素数,即 std::distance(begin(), end()) 对于最大容器。
内容 |
[编辑] 参数
(无)
[编辑] 返回值
最大元素数。
[编辑] 复杂度
常数。
[编辑] 注释
此值通常反映容器大小的理论限制,最多为 std::numeric_limits<difference_type>::max()。在运行时,容器的大小可能会限制为小于 max_size()
的值,具体取决于可用的 RAM 量。
[编辑] 示例
运行此代码
#include <iostream> #include <locale> #include <unordered_map> int main() { std::unordered_map<char, char> p; std::unordered_map<long, char> q; std::cout.imbue(std::locale("en_US.UTF-8")); std::cout << std::uppercase << "p.max_size() = " << std::dec << p.max_size() << " = 0x" << std::hex << p.max_size() << '\n' << "q.max_size() = " << std::dec << q.max_size() << " = 0x" << std::hex << q.max_size() << '\n'; }
可能的输出
p.max_size() = 1,152,921,504,606,846,975 = 0xFFF,FFF,FFF,FFF,FFF q.max_size() = 768,614,336,404,564,650 = 0xAAA,AAA,AAA,AAA,AAA
另请参阅
返回元素数量 (公有成员函数) |