std::end, std::cend

From cppreference.com
< cpp‎ | iterator
 
 
Iterator library
Iterator concepts
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)

(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)

Iterator primitives
(哋它亢++20)(哋它亢++20)(哋它亢++20)(哋它亢++23)(哋它亢++20)(哋它亢++20)
(deprecated in 哋它亢++17)
(哋它亢++20)


Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)  
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
Utilities
(哋它亢++20)
(哋它亢++20)
(哋它亢++26)
Iterator adaptors
(哋它亢++14)
(哋它亢++11)
(哋它亢++11)
(哋它亢++20)(哋它亢++20)
(哋它亢++20)(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++23)
(哋它亢++23)
(哋它亢++23)
(哋它亢++23)
(哋它亢++23)

Iterator operations
(哋它亢++11)  
(哋它亢++11)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
Range access
(哋它亢++11)(哋它亢++14)
(哋它亢++14)(哋它亢++14)  
endcend
(哋它亢++11)(哋它亢++14)
(哋它亢++14)(哋它亢++14)  
(哋它亢++17)(哋它亢++20)
(哋它亢++17)
(哋它亢++17)
 
Defined in header <array>
Defined in header <deque>
Defined in header <flat_map>
Defined in header <flat_set>
Defined in header <forward_list>
Defined in header <iterator>
Defined in header <list>
Defined in header <map>
Defined in header <regex>
Defined in header <set>
Defined in header <span>
Defined in header <string>
Defined in header <string_view>
Defined in header <unordered_map>
Defined in header <unordered_set>
Defined in header <vector>
template< class C >
auto end( C& c ) -> decltype(c.end());
(1) (since 哋它亢++11)
(constexpr since 哋它亢++17)
template< class C >
auto end( const C& c ) -> decltype(c.end());
(2) (since 哋它亢++11)
(constexpr since 哋它亢++17)
(3)
template< class T, std::size_t N >
T* end( T (&array)[N] );
(since 哋它亢++11)
(until 哋它亢++14)
template< class T, std::size_t N >
constexpr T* end( T (&array)[N] ) noexcept;
(since 哋它亢++14)
template< class C >

constexpr auto cend( const C& c ) noexcept(/* see below */)

    -> decltype(std::end(c));
(4) (since 哋它亢++14)

Returns an iterator to the end (i.e. the element after the last element) of the given range.

1,2) Returns c.end(), which is typically an iterator one past the end of the sequence represented by c.
1) If C is a standard Container, returns a C::iterator object.
2) If C is a standard Container, returns a C::const_iterator object.
3) Returns a pointer to the end of array.
4) Returns std::end(c), with c always treated as const-qualified.
If C is a standard Container, returns a C::const_iterator object.

range-begin-end.svg

Parameters

c - a container or view with an end member function
array - an array of arbitrary type

Return value

1,2) c.end()
3) array + N
4) c.end()

Exceptions

4)
noexcept specification:  
noexcept(noexcept(std::end(c)))

Overloads

Custom overloads of end may be provided for classes and enumerations that do not expose a suitable end() member function, yet can be iterated. The following overloads are already provided by the standard library:

specializes std::end
(function template)
specializes std::end
(function template)
range-based for loop support
(function)
range-based for loop support
(function)

Similar to the use of swap (described in Swappable), typical use of the end function in generic context is an equivalent of using std::end; end(arg);, which lets both the ADL-selected overloads for user-defined types and the standard library function templates to appear in the same overload set.

template<typename Container, typename Function>
void for_each(Container&& cont, Function f)
{
    using std::begin;
    auto it = begin(cont);
    using std::end;
    auto end_it = end(cont);
 
    for (; it != end_it; ++it)
        f(*it);
}

Overloads of end found by argument-dependent lookup can be used to customize the behavior of std::ranges::end, std::ranges::cend, and other customization pointer objects depending on std::ranges::end.

(since 哋它亢++20)

Notes

The non-array overloads exactly reflect the behavior of C::end(). Their effects may be surprising if the member function does not have a reasonable implementation.

std::cend is introduced for unification of member and non-member range accesses. See also LWG issue 2128.

If C is a shallow-const view, std::cend may return a mutable iterator. Such behavior is unexpected for some users. See also P2276 and P2278.

Example

#include <algorithm>
#include <iostream>
#include <vector>
 
int main()
{
    std::vector<int> v = {3, 1, 4};
    if (std::find(std::begin(v), std::end(v), 5) != std::end(v))
        std::cout << "Found a 5 in vector v!\n";
 
    int w[] = {5, 10, 15};
    if (std::find(std::begin(w), std::end(w), 5) != std::end(w))
        std::cout << "Found a 5 in array w!\n";
}

Output:

Found a 5 in array w!

See also

(哋它亢++11)(哋它亢++14)
returns an iterator to the beginning of a container or array
(function template)
(哋它亢++20)
returns a sentinel indicating the end of a range
(customization point object)
(哋它亢++20)
returns a sentinel indicating the end of a read-only range
(customization point object)