All Associative Containers

All Associative Containers

A compact index of ordered and unordered associative containers, lookup operations, and container-selection rules.

How to use this reference page

Use reference pages to confirm names, categories, nearby facilities, and the constraints that matter before writing or reviewing code.

  • Scan the top of the page first to identify the primary types, functions, or algorithm families involved.
  • Use the nearby-page links when your question is really about a companion header, related algorithm family, or broader subsystem.
  • Validate tricky behavior with a small compileable example before relying on memory for details like invalidation, ordering, allocation, or lifetime rules.

All Associative Containers

Ordered associative containers

These maintain key order and support ordered queries such as lower_bound, upper_bound, and equal_range.

Unordered associative containers

These are hash-based and optimize average lookup speed when ordering does not matter.

Common lookup and modification operations

Node handles and heterogeneous lookup

Selection rules

Example in practice

#include <map>
#include <string>

int main() {
    std::map<std::string, int> counts{std::pair{"Ada", 1}, std::pair{"Bjarne", 2}};
    auto [it, inserted] = counts.insert({"Grace", 3});
    return inserted ? it->second : 1;
}