Namespaces
Variants

std::multimap<Key,T,Compare,Allocator>:: rend, std::multimap<Key,T,Compare,Allocator>:: crend

From cppreference.net

reverse_iterator rend ( ) ;
(1) (noexcept начиная с C++11)
(constexpr начиная с C++26)
const_reverse_iterator rend ( ) const ;
(2) (noexcept начиная с C++11)
(constexpr начиная с C++26)
const_reverse_iterator crend ( ) const noexcept ;
(3) (начиная с C++11)
(constexpr начиная с C++26)

Возвращает обратный итератор за последним элементом обращенного * this . Он соответствует элементу, предшествующему первому элементу необращенного * this .

Этот возвращённый итератор действует только как sentinel. Не гарантируется, что он будет dereferenceable .

range-rbegin-rend.svg

Содержание

Возвращаемое значение

Обратный итератор на элемент, следующий за последним элементом.

Сложность

Константа.

Примечания

libc++ обратно портирует crend() в режим C++98.

Пример

#include <chrono>
#include <iomanip>
#include <iostream>
#include <string_view>
#include <map>
using namespace std::chrono;
int main()
{
    const std::multimap<year_month_day, int> messages
    {
        {February/17/2023, 10},
        {February/17/2023, 20},
        {February/16/2022, 30},
        {October/22/2022, 40},
        {June/14/2022, 50},
        {November/23/2021, 60},
        {December/10/2022, 55},
        {December/12/2021, 45},
        {April/1/2020, 42},
        {April/1/2020, 24}
    };
    std::cout << "Messages received (date order is reversed):\n";
    for (auto it = messages.crbegin(); it != messages.crend(); ++it)
        std::cout << it->first << " : " << it->second << '\n';
}

Возможный вывод:

Messages received (date order is reversed):
2023-02-17 : 20
2023-02-17 : 10
2022-12-10 : 55
2022-10-22 : 40
2022-06-14 : 50
2022-02-16 : 30
2021-12-12 : 45
2021-11-23 : 60
2020-04-01 : 24
2020-04-01 : 42

Смотрите также

возвращает обратный итератор на начало
(public member function)
(C++14)
возвращает обратный конечный итератор для контейнера или массива
(function template)