Understanding the Design of Containers, Iterators, and Algorithms
Explore the most commonly used containers and their common features in this lesson.
Containers are types that represent collections of elements. These collections can be implemented based on a variety of data structures, each with different semantics: lists, queues, trees, and so on. The standard library provides three categories of containers:
Sequence containers:
vector
,deque
,list
,array
, andforward_list
Associative containers:
set
,map
,multiset
, andmultimap
Unordered associative containers:
unordered_set
,unordered_map
,unordered_multiset
, andunordered_multimap
In addition to this, there are also container adaptors that provide a different interface for sequence containers. This category includes the stack
, queue
, and priority_queue
classes. Finally, there is a class called span
that represents a nonowning view over a contiguous sequence of objects.
The most used containers
The rationale for these containers to be templates was presented in the “Template Basics” section. We don’t want to write the same implementation again and again for each different type of element that we need to store in a container. Arguably, the most used containers from the standard library are the following:
vector
: This is a variable-size collection of elements stored contiguously in memory. It’s the default container we would choose, provided no special requirements are defined. The internal storage expands or shrinks automatically as needed to accommodate the stored elements. The vector allocates more memory than needed so that the risk of having to expand is low. The expansion is a costly operation because new memory needs to be allocated, the content of the current storage needs to be copied to the new one, and lastly, the previous storage needs to be discarded. Because elements are stored contiguously in memory, they can be randomly accessed by an index in constant time.array
: This is a fixed-size collection of elements stored contiguously in memory. The size must be a compile-time constant expression. The semantics of thearray
class is the same as a structure holding a C-style array (T[n]
). Just like thevector
type, the elements of thearray
class can be accessed randomly in constant time.
Get hands-on with 1300+ tech skills courses.