std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::clear
From cppreference.com
< cpp | container | unordered multimap
| void clear() noexcept; |
(C++11以降) | |
コンテナからすべての要素を削除します。この呼び出しの後、size() はゼロを返します。
コンテナ内の要素を参照するすべての参照、ポインタ、およびイテレータを無効にします。末尾を越えたイテレータも無効にする可能性があります。
目次 |
[編集] 複雑性
コンテナのサイズ、つまり要素数に線形です。
[編集] 例
このコードを実行
#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++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 2550 | C++11 | 順序なし連想コンテナに関して、複雑さが不明瞭でした。 要素数またはバケット数に対して線形であるか |
要素数に対して線形であることが明確化されました。 |
[編集] 関連項目
| 要素を削除する (公開メンバ関数) |