std::unordered_multiset<Key,Hash,KeyEqual,Allocator>::clear
From cppreference.com
< cpp | コンテナ | unordered_multiset
| void clear() noexcept; |
(C++11以降) | |
コンテナからすべての要素を削除します。この呼び出しの後、size() はゼロを返します。
コンテナ内の要素を参照するすべての参照、ポインタ、およびイテレータを無効にします。末尾を越えたイテレータも無効にする可能性があります。
目次 |
[編集] 複雑性
コンテナのサイズ、つまり要素数に線形です。
[編集] 例
このコードを実行
#include <iostream> #include <string_view> #include <unordered_set> void print_info(std::string_view rem, const std::unordered_multiset<int>& v) { std::cout << rem << "{ "; for (const auto& value : v) std::cout << value << ' '; std::cout << "}\n"; std::cout << "Size=" << v.size() << '\n'; } int main() { std::unordered_multiset<int> container{1, 2, 3}; print_info("Before clear: ", container); container.clear(); print_info("After clear: ", container); }
実行結果の例
Before clear: { 1 2 3 }
Size=3
After clear: { }
Size=0欠陥レポート
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 2550 | C++11 | 順序なし連想コンテナに関して、複雑さが不明瞭でした。 要素数またはバケット数に対して線形であるか |
要素数に対して線形であることが明確化されました。 |
[編集] 関連項目
| 要素を削除する (公開メンバ関数) |