std::unordered_set<Key,Hash,KeyEqual,Allocator>:: clear
From cppreference.net
<
cpp
|
container
|
unordered set
C++
Containers library
|
(C++17)
|
||||
| Sequence | ||||
|
(C++11)
|
||||
|
(C++26)
|
||||
|
(C++26)
|
||||
|
(C++11)
|
||||
| Associative | ||||
| Unordered associative | ||||
|
(C++11)
|
||||
|
(C++11)
|
||||
|
(C++11)
|
||||
|
(C++11)
|
||||
| Adaptors | ||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
| Views | ||||
|
(C++20)
|
||||
|
(C++23)
|
||||
| Tables | ||||
| Iterator invalidation | ||||
| Member function table | ||||
| Non-member function table |
std::unordered_set
| Member types | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Non-member functions | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Deduction guides (C++17) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
void
clear
(
)
noexcept
;
|
(начиная с C++11)
(constexpr начиная с C++26) |
|
Удаляет все элементы из контейнера. После этого вызова size() возвращает ноль.
Аннулирует любые ссылки, указатели и итераторы, ссылающиеся на содержащиеся элементы. Также может аннулировать итераторы, указывающие за конец контейнера.
Содержание |
Сложность
Линейно относительно размера контейнера, то есть количества элементов.
Пример
Запустить этот код
#include <iostream> #include <string_view> #include <unordered_set> void print_info(std::string_view rem, const std::unordered_set<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_set<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 | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 2550 | C++11 |
для неупорядоченных ассоциативных контейнеров неясно, является ли сложность
линейной по количеству элементов или по количеству сегментов |
уточнено, что она линейна по количеству элементов |
Смотрите также
|
удаляет элементы
(публичная функция-член) |