Namespaces
Variants

std::ranges:: random_access_range

From cppreference.net
Ranges library
Range adaptors
헤더에 정의됨 <ranges>
template < class T >

concept random_access_range =

ranges:: bidirectional_range < T > && std:: random_access_iterator < ranges:: iterator_t < T >> ;
(C++20 이후)

random_access_range 개념은 range 의 정제된 개념으로, ranges::begin random_access_iterator 를 모델로 하는 반복자를 반환하는 범위입니다.

예제

#include <array>
#include <deque>
#include <list>
#include <ranges>
#include <set>
#include <valarray>
#include <vector>
template<typename T> concept RAR = std::ranges::random_access_range<T>;
int main()
{
    int a[4];
    static_assert(
            RAR<std::vector<int>> and
            RAR<std::vector<bool>> and
            RAR<std::deque<int>> and
            RAR<std::valarray<int>> and
            RAR<decltype(a)> and
        not RAR<std::list<int>> and
        not RAR<std::set<int>> and
            RAR<std::array<std::list<int>,42>>
    );
}

참고 항목

범위가 자신의 크기를 상수 시간에 알 수 있음을 명시
(concept)
반복자 타입이 contiguous_iterator 를 만족하는 범위를 명시
(concept)