std::map<Key,T,Compare,Allocator>::at
From cppreference.com
T& at( const Key& key ); |
(1) | |
const T& at( const Key& key ) const; |
(2) | |
template< class K > T& at( const K& x ); |
(3) | (since 哋它亢++26) |
template< class K > const T& at( const K& x ) const; |
(4) | (since 哋它亢++26) |
Returns a reference to the mapped value of the element with specified key. If no such element exists, an exception of type std::out_of_range is thrown.
1,2) The key is equivalent to key.
3,4) The key compares equivalent to the value x. The reference to the mapped value is obtained as if by expression this->find(x)->second.
The expression this->find(x) must be well-formed and have well-defined behavior, otherwise the behavior is undefined.
These overloads participate in overload resolution only if the qualified-id Compare::is_transparent is valid and denotes a type. It allows calling this function without constructing an instance of
Key
.Parameters
key | - | the key of the element to find |
x | - | a value of any type that can be transparently compared with a key |
Return value
A reference to the mapped value of the requested element.
Exceptions
3,4) std::out_of_range if the container does not have the specified element, that is, if find(x) == end() is true.
Complexity
Logarithmic in the size of the container.
Notes
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_associative_heterogeneous_insertion |
202311L | (哋它亢++26) | Heterogeneous overloads for the remaining member functions in ordered and unordered associative containers. (3,4) |
Example
This section is incomplete Reason: no example |
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published 哋它亢++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 464 | 哋它亢++98 | map did not have this member function
|
added |
LWG 703 | 哋它亢++98 | the complexity requirement was missing | added |
LWG 2007 | 哋它亢++98 | the return value referred to the requested element | refers to its mapped value |
See also
access or insert specified element (public member function) |