Namespaces
Variants

std:: rbegin, std:: crbegin

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
rbegin crbegin
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
헤더에 정의됨 <array>
헤더 파일에 정의됨 <deque>
헤더에 정의됨 <flat_map>
헤더에 정의됨 <flat_set>
헤더 파일에 정의됨 <forward_list>
헤더에 정의됨 <inplace_vector>
헤더 파일에 정의됨 <iterator>
헤더 파일에 정의됨 <list>
헤더에 정의됨 <map>
헤더 파일에 정의됨 <regex>
헤더에 정의됨 <set>
헤더에 정의됨 <span>
헤더에 정의됨 <string>
헤더에 정의됨 <string_view>
헤더 파일에 정의됨 <unordered_map>
헤더 파일에 정의됨 <unordered_set>
헤더 파일에 정의됨 <vector>
template < class C >
auto rbegin ( C & c ) - > decltype ( c. rbegin ( ) ) ;
(1) (C++14부터)
(C++17부터 constexpr)
template < class C >
auto rbegin ( const C & c ) - > decltype ( c. rbegin ( ) ) ;
(2) (C++14 이후)
(C++17 이후 constexpr)
template < class T, std:: size_t N >
std:: reverse_iterator < T * > rbegin ( T ( & array ) [ N ] ) ;
(3) (C++14 이후)
(C++17 이후 constexpr)
template < class T >
std:: reverse_iterator < const T * > rbegin ( std:: initializer_list < T > il ) ;
(4) (C++14 이후)
(C++17 이후 constexpr)
template < class C >
auto crbegin ( const C & c ) - > decltype ( std :: rbegin ( c ) ) ;
(5) (C++14 이후)
(C++17 이후 constexpr)

주어진 범위의 역방향 시작 부분에 대한 반복자를 반환합니다.

1,2) c. rbegin ( ) 을 반환합니다. 이는 일반적으로 c 가 나타내는 시퀀스의 역방향 시작을 가리키는 반복자입니다.
1) 만약 C 가 표준 Container 라면, C::reverse_iterator 객체를 반환합니다.
2) 만약 C 가 표준 Container 인 경우, C::const_reverse_iterator 객체를 반환합니다.
3) std:: reverse_iterator < T * > 객체를 array 의 역방향 시작 부분에 반환합니다.
4) std:: reverse_iterator < const T * > 객체를 il 의 역방향 시작 부분에 반환합니다.
5) 반환값 std :: rbegin ( c ) , c 는 항상 const로 한정된 것으로 처리됩니다.
만약 C 가 표준 Container 라면, C::const_reverse_iterator 객체를 반환합니다.

range-rbegin-rend.svg

목차

매개변수

c - rbegin 멤버 함수를 가진 컨테이너 또는 뷰
array - 임의 타입의 배열
il - std:: initializer_list

반환값

1,2) c. rbegin ( )
3) std:: reverse_iterator < T * > ( array + N )
4) std:: reverse_iterator < const T * > ( il. end ( ) )
5) c. rbegin ( )

예외

구현 정의 예외를 던질 수 있습니다.

오버로드

적합한 rbegin() 멤버 함수를 노출하지 않지만 반복 가능한 클래스 및 열거형에 대해 rbegin 의 사용자 정의 오버로드를 제공할 수 있습니다.

인수 종속 탐색 으로 찾은 rbegin 의 오버로드는 std :: ranges:: rbegin std::ranges::crbegin 의 동작을 사용자 정의하는 데 사용할 수 있습니다.

(C++20 이후)

참고 사항

std::initializer_list 에 대한 오버로드는 rbegin 멤버 함수를 가지고 있지 않기 때문에 필요합니다.

예제

#include <iostream>
#include <iterator>
#include <vector>
int main()
{
    std::vector<int> v = {3, 1, 4};
    auto vi = std::rbegin(v); // "vi"의 타입은 std::vector<int>::reverse_iterator
    std::cout << "*vi = " << *vi << '\n';
    *std::rbegin(v) = 42; // OK: 할당 후 v[2] == 42
//  *std::crbegin(v) = 13; // 오류: 해당 위치는 읽기 전용입니다
    int a[] = {-5, 10, 15};
    auto ai = std::rbegin(a); // "ai"의 타입은 std::reverse_iterator<int*>
    std::cout << "*ai = " << *ai << '\n';
    auto il = {3, 1, 4};
    // 아래 "it"의 타입은 std::reverse_iterator<int const*>입니다:
    for (auto it = std::rbegin(il); it != std::rend(il); ++it)
        std::cout << *it << ' ';
    std::cout << '\n';
}

출력:

*vi = 4
*ai = 15
4 1 3

참고 항목

(C++11) (C++14)
컨테이너나 배열의 시작 부분을 가리키는 반복자를 반환합니다
(함수 템플릿)
(C++11) (C++14)
컨테이너나 배열의 끝 부분을 가리키는 반복자를 반환합니다
(함수 템플릿)
(C++14)
컨테이너나 배열의 역방향 끝 반복자를 반환합니다
(함수 템플릿)
범위에 대한 역방향 반복자를 반환합니다
(커스터마이제이션 포인트 객체)
읽기 전용 범위에 대한 역방향 반복자를 반환합니다
(커스터마이제이션 포인트 객체)