Namespaces
Variants

std::ranges:: begin

From cppreference.net
Ranges library
Range adaptors
Определено в заголовочном файле <ranges>
Определено в заголовочном файле <iterator>
inline namespace /* unspecified */ {

inline constexpr /* unspecified */ begin = /* unspecified */ ;

}
(since C++20)
(объект точки кастомизации)
Сигнатура вызова
template < class T >

requires /* see below */

constexpr std:: input_or_output_iterator auto begin ( T && t ) ;
(since C++20)

Возвращает итератор на первый элемент аргумента.

range-begin-end.svg

Если аргумент является lvalue или ranges:: enable_borrowed_range < std:: remove_cv_t < T >> равно true , тогда вызов ranges::begin является эквивалентным по выражению следующему:

  1. t + 0 если t имеет тип массива.
  2. Иначе, decay-copy ( t. begin ( ) ) (до C++23) auto ( t. begin ( ) ) (начиная с C++23) , если это выражение допустимо и его тип моделирует std::input_or_output_iterator .
  3. Иначе, decay-copy ( begin ( t ) ) (до C++23) auto ( begin ( t ) ) (начиная с C++23) , если T является классом или типом перечисления, это выражение допустимо и его тип моделирует std::input_or_output_iterator , где значение begin устанавливается как если бы выполнялся только поиск, зависимый от аргументов .

Во всех остальных случаях вызов ranges::begin является некорректным, что может привести к ошибке подстановки , когда вызов находится в непосредственном контексте инстанцирования шаблона.

Содержание

Объекты точек кастомизации

Имя ranges::begin обозначает объект точки кастомизации , который является константным функциональным объектом типа литерального semiregular класса. Для подробностей см. CustomizationPointObject .

Примечания

Если аргумент является rvalue (т.е. T является объектным типом) и ranges:: enable_borrowed_range < std:: remove_cv_t < T >> равно false , вызов ranges::begin является некорректным, что также приводит к ошибке подстановки.

Возвращаемый тип моделирует std::input_or_output_iterator во всех случаях.

Стандарт C++20 требует, чтобы если базовый вызов функции begin возвращает prvalue, возвращаемое значение создавалось перемещением из материализованного временного объекта. Все реализации напрямую возвращают prvalue вместо этого. Требование исправлено пост-C++20 предложением P0849R8 для соответствия реализациям.

Пример

#include <cassert>
#include <ranges>
#include <vector>
int main() 
{
    std::vector v{3, 1, 4};
    auto vi = std::ranges::begin(v);
    auto vci = std::ranges::cbegin(v);
    assert(*vi == 3 and *vi == *vci);
    ++vi;
    ++vci; // OK: vci является изменяемым объектом
    *vi = 42; // OK: vi указывает на изменяемый элемент
    // *vci = 13; // Ошибка: vci указывает на неизменяемый элемент
    int a[]{-5, 10, 15};
    auto ai = std::ranges::begin(a); // работает и с C-массивами
    assert(*ai == -5);
    *ai = 42; // OK
}

Отчеты о дефектах

Следующие отчеты о дефектах, изменяющих поведение, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Применяется к Поведение как опубликовано Корректное поведение
P2602R2 C++20 существует механизм для запрета определенных не-членов begin найденных через ADL удален такой механизм

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

возвращает итератор на начало диапазона только для чтения
(объект точки кастомизации)
(C++11) (C++14)
возвращает итератор на начало контейнера или массива
(шаблон функции)