Namespaces
Variants

std::unordered_map<Key,T,Hash,KeyEqual,Allocator>:: clear

From cppreference.net

void clear ( ) noexcept ;
(C++11부터)
(C++26부터 constexpr)

컨테이너의 모든 요소를 지웁니다. 이 호출 이후, size() 는 0을 반환합니다.

포함된 요소를 참조하는 모든 레퍼런스, 포인터, 반복자를 무효화합니다. past-the-end 반복자도 무효화할 수 있습니다.

목차

복잡도

컨테이너 크기에 선형적으로 비례, 즉 요소의 개수에 비례합니다.

예제

#include <iostream>
#include <string_view>
#include <unordered_map>
void print_info(std::string_view rem, const std::unordered_map<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_map<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 unordered 연관 컨테이너의 경우 복잡도가 요소 수에 대한 선형인지
버킷 수에 대한 선형인지 불명확
요소 수에 대한 선형임을 명확히 함

참고 항목

요소를 삭제합니다
(public member function)