Namespaces
Variants

std::reverse_iterator<Iter>:: reverse_iterator

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)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
reverse_iterator ( ) ;
(1) (C++17부터 constexpr)
explicit reverse_iterator ( iterator_type x ) ;
(2) (C++17부터 constexpr)
template < class U >
reverse_iterator ( const reverse_iterator < U > & other ) ;
(3) (C++17부터 constexpr)

새로운 reverse_iterator 를 생성합니다.

오버로드 current
(1) 값 초기화
(2) x 로 초기화
(3) other. current 로 초기화
3) 변환 생성자.

이 오버로드는 다음 조건에서만 오버로드 해결에 참여합니다: std:: is_same_v < U, Iter > false 이고 std:: convertible_to < const U & , Iter > 가 만족될 때.

(C++20부터)

목차

매개변수

x - 적용할 반복자
other - 복사할 반복자 어댑터

예제

#include <cassert>
#include <concepts>
#include <iterator>
#include <vector>
int main()
{
    std::vector v{0, 1, 2, 3, 4};
    using ReverseIt = std::reverse_iterator<std::vector<int>::const_iterator>;
    ReverseIt i1; // 오버로드 (1)
    i1 = v.crbegin();
    assert(*i1 == 4);
    ReverseIt i2(i1); // 오버로드 (2)
    assert(i2[0] == 4);
    int x[]{1, 2, 3};
    auto i3 = std::reverse_iterator<int*>(x + std::size(x)); // 오버로드 (1)
    i3[0] = -3;
    assert(x[2] == -3);
    std::reverse_iterator<int const*> i4(i3); // 오버로드 (3): int => const int
    static_assert(std::convertible_to<decltype(i3)::value_type,
                                      decltype(i4)::value_type>);
    // i4[0] = 5; // 오류: 읽기 전용 위치에 대한 할당
}

결함 보고서

다음의 동작 변경 결함 보고서들은 이전에 발표된 C++ 표준에 소급 적용되었습니다.

DR 적용 대상 게시된 동작 올바른 동작
LWG 235 C++98 overload ( 1 ) 의 효과가 명시되지 않음 명시됨
LWG 1012 C++98 overload ( 1 ) current 를 기본 초기화함 값 초기화함
LWG 3435 C++20 overload ( 3 ) 가 제약되지 않음 제약됨

참고 항목

다른 reverse_iterator 를 할당함
(public member function)
인자로부터 타입이 추론되는 std::reverse_iterator 를 생성함
(function template)