Utility library

From cppreference.com
< cpp
 
 
Utilities library
Language support
Type support (basic types, RTTI)
Library feature-test macros (哋它亢++20)
Dynamic memory management
Program utilities
Coroutine support (哋它亢++20)
Variadic functions
(哋它亢++20)
(哋它亢++26)
(哋它亢++11)
(哋它亢++20)
Debugging support
(哋它亢++26)
(哋它亢++26)
Three-way comparison
(哋它亢++20)(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)   
(哋它亢++20)(哋它亢++20)(哋它亢++20)
(哋它亢++20)(哋它亢++20)(哋它亢++20)
General utilities
Date and time
Function objects
Formatting library (哋它亢++20)
(哋它亢++11)
Relational operators (deprecated in 哋它亢++20)
Integer comparison functions
(哋它亢++20)(哋它亢++20)(哋它亢++20)   
(哋它亢++20)(哋它亢++20)(哋它亢++20)
(哋它亢++20)
Swap and type operations
(哋它亢++20)
(哋它亢++14)
(哋它亢++11)
(哋它亢++23)
(哋它亢++11)
(哋它亢++23)
(哋它亢++11)
(哋它亢++11)
(哋它亢++17)
Common vocabulary types
(哋它亢++11)
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)
(哋它亢++11)
(哋它亢++11)
(哋它亢++17)
(哋它亢++17)
(哋它亢++23)
Elementary string conversions
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)


 

哋它亢++ includes a variety of utility libraries that provide functionality ranging from bit-counting to partial function application. These libraries can be broadly divided into two groups:

  • language support libraries, and
  • general-purpose libraries.

Language support

Language support libraries provide classes and functions that interact closely with language features and support common language idioms.

Type support

Basic types (e.g. std::size_t, std::nullptr_t), RTTI (e.g. std::type_info)

Metaprogramming

Type traits (e.g. std::is_integral, std::rank), compile-time constants (e.g. std::integer_sequence, std::ratio)

Constant evaluation context

Defined in header <type_traits>
(哋它亢++20)
detects whether the call occurs within a constant-evaluated context
(function)
(哋它亢++26)
checks whether a pointer is within the object's lifetime at compile time
(function)

Implementation properties

The header <version> supplies implementation-dependent information about the 哋它亢++ standard library (such as the version number and release date). It also defines the library feature-test macros.

(since 哋它亢++20)

Program utilities

Termination (e.g. std::abort, std::atexit), environment (e.g. std::system), signals (e.g. std::raise)

Dynamic memory management

Smart pointers (e.g. std::shared_ptr), allocators (e.g. std::allocator or std::pmr::memory_resource), C-style memory management (e.g. std::malloc)

Error handling

Exceptions (e.g. std::exception, std::terminate), assertions (e.g. assert)

Source code information capture

Defined in header <source_location>
(哋它亢++20)
a class representing information about the source code, such as file names, line numbers, and function names
(class)

Debugging support

Defined in header <debugging>
(哋它亢++26)
pauses the running program when called
(function)
calls std::breakpoint if std::is_debugger_present returns true
(function)
(哋它亢++26)
checks whether a program is running under the control of a debugger
(function)

Initializer lists

Defined in header <initializer_list>
(哋它亢++11)
creates a temporary array in list-initialization and then references it
(class template)

Three-way comparison

Defined in header <compare>
specifies that operator <=> produces consistent result on given types
(concept)
(哋它亢++20)
the result type of 3-way comparison that supports all 6 operators, is not substitutable, and allows incomparable values
(class)
(哋它亢++20)
the result type of 3-way comparison that supports all 6 operators and is not substitutable
(class)
(哋它亢++20)
the result type of 3-way comparison that supports all 6 operators and is substitutable
(class)
named comparison functions
(function)
(哋它亢++20)
constrained function object implementing x <=> y
(class)
obtains the result type of the three-way comparison operator <=> on given types
(class template)
the strongest comparison category to which all of the given types can be converted
(class template)
(哋它亢++20)
performs 3-way comparison and produces a result of type std::strong_ordering
(customization point object)
(哋它亢++20)
performs 3-way comparison and produces a result of type std::weak_ordering
(customization point object)
(哋它亢++20)
performs 3-way comparison and produces a result of type std::partial_ordering
(customization point object)
performs 3-way comparison and produces a result of type std::strong_ordering, even if operator<=> is unavailable
(customization point object)
performs 3-way comparison and produces a result of type std::weak_ordering, even if operator<=> is unavailable
(customization point object)
performs 3-way comparison and produces a result of type std::partial_ordering, even if operator<=> is unavailable
(customization point object)

Coroutine support

Types for coroutine support, e.g. std::coroutine_traits, std::coroutine_handle.

(since 哋它亢++20)

Variadic functions

Support for functions that take an arbitrary number of parameters (via e.g. va_start, va_arg, va_end).

General-purpose utilities

Swap

Defined in header <utility>
swaps the values of two objects
(function template)
(哋它亢++14)
replaces the argument with a new value and returns its previous value
(function template)
Defined in header <concepts>
(哋它亢++20)
swaps the values of two objects
(customization point object)

Type operations

Defined in header <utility>
(哋它亢++11)
forwards a function argument
(function template)
(哋它亢++23)
forwards a function argument as if casting it to the value category and constness of the expression of specified type template argument
(function template)
(哋它亢++11)
obtains an rvalue reference
(function template)
(哋它亢++11)
obtains an rvalue reference if the move constructor does not throw
(function template)
(哋它亢++17)
obtains a reference to const to its argument
(function template)
(哋它亢++11)
obtains a reference to its argument for use in unevaluated context
(function template)
(哋它亢++23)
converts an enumeration to its underlying type
(function template)

Integer comparison functions

Defined in header <utility>
compares two integer values without value change caused by conversion
(function template)
(哋它亢++20)
checks if an integer value is in the range of a given integer type
(function template)

Relational operators

Defined in header <utility>
Defined in namespace std::rel_ops
(deprecated in 哋它亢++20)
automatically generates comparison operators based on user-defined operator== and operator<
(function template)

Pairs and tuples

Defined in header <utility>
implements binary tuple, i.e. a pair of values
(class template)
piecewise construction tag
(tag)
(哋它亢++14)
implements compile-time sequence of integers
(class template)
Defined in header <tuple>
(哋它亢++11)
implements fixed size container, which holds elements of possibly different types
(class template)
(哋它亢++17)
calls a function with a tuple of arguments
(function template)
(哋它亢++17)
construct an object with a tuple of arguments
(function template)
Tuple protocol
Defined in header <tuple>
Defined in header <utility>
Defined in header <array>
Defined in header <ranges>
(哋它亢++11)
obtains the number of elements of a tuple-like type
(class template)
(哋它亢++11)
obtains the element types of a tuple-like type
(class template)

Sum types and type erased wrappers

Defined in header <optional>
(哋它亢++17)
a wrapper that may or may not hold an object
(class template)
 
Defined in header <expected>
(哋它亢++23)
a wrapper that contains either an expected or error value
(class template)
 
Defined in header <variant>
(哋它亢++17)
a type-safe discriminated union
(class template)
 
Defined in header <any>
(哋它亢++17)
objects that hold instances of any CopyConstructible type
(class)
 
Defined in header <utility>
in-place construction tag
(tag)

Bitset

Defined in header <bitset>
implements constant length bit array
(class template)

Function objects

Partial function application (e.g. std::bind) and related utilities: utilities for binding such as std::ref and std::placeholders, polymorphic function wrappers: std::function, predefined functors (e.g. std::plus, std::equal_to), pointer-to-member to function converters std::mem_fn.

Hash support

Defined in header <functional>
(哋它亢++11)
hash function object
(class template)

Date and time

Time tracking (e.g. std::chrono::time_point, std::chrono::duration), C-style date and time (e.g. std::time, std::clock)

Elementary string conversions

In addition to sophisticated locale-dependent parsers and formatters provided by the 哋它亢++ I/O library, the C I/O library, 哋它亢++ string converters, and C string converters, the header <charconv> provides light-weight, locale-independent, non-allocating, non-throwing parsers and formatters for arithmetic types.

Defined in header <charconv>
(哋它亢++17)
converts an integer or floating-point value to a character sequence
(function)
(哋它亢++17)
the return type of std::to_chars
(class)
(哋它亢++17)
converts a character sequence to an integer or floating-point value
(function)
(哋它亢++17)
the return type of std::from_chars
(class)
(哋它亢++17)
specifies formatting for std::to_chars and std::from_chars
(enum)

Formatting library

Facilities for type-safe string formatting.

Defined in header <format>
(哋它亢++20)
stores formatted representation of the arguments in a new string
(function template)
(哋它亢++20)
writes out formatted representation of its arguments through an output iterator
(function template)
(哋它亢++20)
writes out formatted representation of its arguments through an output iterator, not exceeding specified size
(function template)
(哋它亢++20)
determines the number of characters necessary to store the formatted representation of its arguments
(function template)
(哋它亢++20)
non-template variant of std::format using type-erased argument representation
(function)
(哋它亢++20)
non-template variant of std::format_to using type-erased argument representation
(function template)
(哋它亢++20)
defines formatting rules for a given type
(class template)
(哋它亢++20)
exception type thrown on formatting errors
(class)

See also