std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::clear
来自cppreference.com
< cpp | container | unordered multimap
void clear() noexcept; |
(C++11 起) | |
从容器擦除所有元素。此调用后 size() 返回零。
非法化任何指代所含元素的引用、指针或迭代器。可能会使尾后迭代器也失效。
参数
(无)
返回值
(无)
复杂度
与容器大小,即元素数成线性。
示例
运行此代码
#include <algorithm> #include <iostream> #include <unordered_map> int main() { std::unordered_multimap<int, char> container{{1, 'x'}, {2, 'y'}, {3, 'z'}}; auto print = [](std::pair<const int, char>& n) { std::cout << " " << n.first << '(' << n.second << ')'; }; std::cout << "clear 前:"; std::for_each(container.begin(), container.end(), print); std::cout << "\n大小=" << container.size() << '\n'; std::cout << "执行 clear()\n"; container.clear(); std::cout << "clear 后:"; std::for_each(container.begin(), container.end(), print); std::cout << "\n大小=" << container.size() << '\n'; }
可能的输出:
clear 前:1(x) 2(y) 3(z) 大小=3 执行 clear() clear 后: 大小=0
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为
|
---|---|---|---|
LWG 2550 | C++11 | 对于无序关联容器,不清楚复杂度是与元素数还是桶数成线性 | 辨明它与元素数成线性 |
参阅
(C++11) |
擦除元素 (公开成员函数) |