std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::clear
來自 cppreference.com
void clear() noexcept; |
(C++11 起) | |
從容器中擦除所有元素。此呼叫後,size() 返回零。
使所有引用、指標和指向所含元素的迭代器失效。也可能使 past-the-end 迭代器失效。
目錄 |
[edit] 複雜度
與容器大小(即元素數量)呈線性關係。
[edit] 示例
執行此程式碼
#include <iostream> #include <string_view> #include <unordered_map> void print_info(std::string_view rem, const std::unordered_multimap<int, char>& v) { std::cout << rem << "{ "; for (const auto& [key, value] : v) std::cout << '[' << key << "]:" << value << ' '; std::cout << "}\n"; std::cout << "Size=" << v.size() << '\n'; } int main() { std::unordered_multimap<int, char> container{{1, 'x'}, {2, 'y'}, {3, 'z'}}; print_info("Before clear: ", container); container.clear(); print_info("After clear: ", container); }
可能的輸出
Before clear: { [1]:x [2]:y [3]:z } Size=3 After clear: { } Size=0
缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 2550 | C++11 | 對於無序關聯容器,不清楚複雜度是 與元素數量呈線性關係還是與桶數量呈線性關係 |
澄清為與元素數量呈線性關係 |
[edit] 參閱
擦除元素 (public 成員函式) |