In the programming language
C++, unordered associative containers are a group of class templates in the
C++ Standard Library
The C standard library, sometimes referred to as libc, is the standard library for the C programming language, as specified in the ISO C standard.ISO/ IEC (2018). '' ISO/IEC 9899:2018(E): Programming Languages - C ยง7'' Starting from the origina ...
that implement
hash table
In computer science, a hash table is a data structure that implements an associative array, also called a dictionary or simply map; an associative array is an abstract data type that maps Unique key, keys to Value (computer science), values. ...
variants. Being
templates, they can be used to store arbitrary elements, such as integers or custom classes. The following containers are defined in the current revision of the C++ standard:
unordered_set
,
unordered_map
,
unordered_multiset
,
unordered_multimap
. Each of these containers differ only on constraints placed on their elements.
The unordered associative containers are similar to the
associative containers in the C++ Standard Library but have different constraints. As their name implies, the elements in the unordered associative containers are not
ordered. This is due to the use of hashing to store objects. The containers can still be
iterated through like a regular associative container.
History
The first widely used implementation of hash tables in the C++ language was
hash_map
,
hash_set
,
hash_multimap
,
hash_multiset
class templates of the
Silicon Graphics
Silicon Graphics, Inc. (stylized as SiliconGraphics before 1999, later rebranded SGI, historically known as Silicon Graphics Computer Systems or SGCS) was an American high-performance computing manufacturer, producing computer hardware and soft ...
(SGI)
Standard Template Library
The Standard Template Library (STL) is a software library originally designed by Alexander Stepanov for the C++ programming language that influenced many parts of the C++ Standard Library. It provides four components called ''algorithms'', '' ...
(STL). Due to their usefulness, they were later included in several other implementations of the C++ Standard Library (e.g., the
GNU Compiler Collection
The GNU Compiler Collection (GCC) is a collection of compilers from the GNU Project that support various programming languages, Computer architecture, hardware architectures, and operating systems. The Free Software Foundation (FSF) distributes ...
's (GCC)
libstdc++ and the
Visual C++
Microsoft Visual C++ (MSVC) is a compiler for the C, C++, C++/CLI and C++/CX programming languages by Microsoft. MSVC is proprietary software; it was originally a standalone product but later became a part of Visual Studio and made available ...
(MSVC) standard library).
The
hash_*
class templates were proposed into
C++ Technical Report 1 (C++ TR1) and were accepted under names
unordered_*
. Later, they were incorporated into the
C++11
C++11 is a version of a joint technical standard, ISO/IEC 14882, by the International Organization for Standardization (ISO) and International Electrotechnical Commission (IEC), for the C++ programming language. C++11 replaced the prior vers ...
revision of the C++ standard.
An implementation is also available in the
Boost C++ Libraries
Boost, boosted or boosting may refer to:
Science, technology and mathematics
* Boost, positive manifold pressure in turbocharged engines
* Boost (C++ libraries), a set of free peer-reviewed portable C++ libraries
* Boost (material), a material b ...
as
.
Overview of functions
The containers are defined in headers named after the names of the containers, e.g.,
unordered_set
is defined in header
. All containers satisfy the requirements of th
Containerconcept
A concept is an abstract idea that serves as a foundation for more concrete principles, thoughts, and beliefs.
Concepts play an important role in all aspects of cognition. As such, concepts are studied within such disciplines as linguistics, ...
, which means they have
begin()
,
end()
,
size()
,
max_size()
,
empty()
, and
swap()
methods.
Usage example
#include
#include
#include
int main()
Custom hash functions
To use custom objects in std::unordered_map, a custom hash function must be defined. This function takes a const reference to the custom type and returns a size_t
#include
struct X;
struct hash_X;
The user defined function can be used as is in std::unordered_map, by passing it as a template parameter
std::unordered_map my_map;
Or can be set as the default hash function by specializing the std::hash function
namespace std
//...
std::unordered_map my_map;
References
{{Reflist
Articles with example C++ code
C++ Standard Library