std::ranges:: views:: slide, std::ranges:: slide_view
|
헤더 파일에 정의됨
<ranges>
|
||
|
template
<
ranges::
forward_range
V
>
requires
ranges::
view
<
V
>
|
(1) | (C++23부터) |
|
namespace
views
{
inline
constexpr
/* 지정되지 않음 */
slide
=
/* 지정되지 않음 */
;
|
(2) | (C++23부터) |
|
호출 시그니처
|
||
|
template
<
ranges::
viewable_range
R
>
constexpr ranges:: view auto slide ( R && r, ranges:: range_difference_t < R > n ) ; |
(C++23부터) | |
|
template
<
class
DifferenceType
>
constexpr /* 범위 어댑터 객체 */ slide ( DifferenceType && n ) ; |
(C++23부터) | |
|
헬퍼 개념
|
||
|
template
<
class
V
>
concept
/*slide-caches-nothing*/
=
|
(3) | ( 설명 전용* ) |
|
template
<
class
V
>
concept
/*slide-caches-last*/
=
|
(4) | ( 설명 전용* ) |
|
template
<
class
V
>
concept
/*slide-caches-first*/
=
|
(5) | ( 설명 전용* ) |
slide_view
는
view
와 숫자
n
을 취하는 범위 어댑터로, 해당 뷰의
m
th
번째 요소("윈도우")가 원본 뷰의
[
m
,
m + n - 1
]
요소들에 대한 뷰인 뷰를 생성합니다.
- s - n + 1 , 만약 s >= n 인 경우,
- 0 그렇지 않은 경우, 결과 뷰는 비어 있습니다.
만약 n 이 0 보다 크지 않으면, 동작은 정의되지 않습니다.
slide_view
는 항상
forward_range
를 모델하며, 적응된
view
타입이 해당 개념을 모델할 경우
bidirectional_range
,
random_access_range
, 또는
sized_range
를 모델합니다.
목차 |
데이터 멤버
| 멤버 | 설명 |
V
base_
|
기본 뷰
( 설명 전용 멤버 객체* ) |
ranges::
range_difference_t
<
V
>
n_
|
"윈도우" 크기
( 설명 전용 멤버 객체* ) |
non-propagating-cache
<
ranges::
iterator_t
<
V
>>
cached_begin_
(다음 경우에만 존재:
V
가 다음을 모델링할 때
slide-caches-first
)
|
begin()
의 결과를 캐싱하는 객체
( 설명 전용 멤버 객체* ) |
non-propagating-cache
<
ranges::
iterator_t
<
V
>>
cached_end_
(다음 경우에만 존재:
V
가 다음을 모델링할 때
slide-caches-last
)
|
end()
의 결과를 캐싱하는 객체
( 설명 전용 멤버 객체* ) |
멤버 함수
slide_view
를 생성합니다
(public 멤버 함수) |
|
|
시작 부분에 대한 반복자를 반환합니다
(public 멤버 함수) |
|
|
끝 부분에 대한 반복자나 센티널을 반환합니다
(public 멤버 함수) |
|
기본(적응된) 범위가
sized_range
를 만족할 때만 제공되는 요소의 개수를 반환합니다
(public 멤버 함수) |
|
|
(C++26)
|
결과
approximately_sized_range
의 대략적인 크기를 반환합니다
(public 멤버 함수) |
std::ranges::view_interface 에서 상속됨 |
|
파생 뷰가 비어 있는지 여부를 반환합니다.
sized_range
나
forward_range
를 만족할 때만 제공됩니다
(
std::ranges::view_interface<D>
의 public 멤버 함수)
|
|
|
(C++23)
|
범위의 시작 부분에 대한 상수 반복자를 반환합니다
(
std::ranges::view_interface<D>
의 public 멤버 함수)
|
|
(C++23)
|
범위의 상수 반복자에 대한 센티널을 반환합니다
(
std::ranges::view_interface<D>
의 public 멤버 함수)
|
|
파생 뷰가 비어 있지 않은지 여부를 반환합니다.
ranges::empty
가 적용 가능할 때만 제공됩니다
(
std::ranges::view_interface<D>
의 public 멤버 함수)
|
|
파생 뷰의 첫 번째 요소를 반환합니다.
forward_range
를 만족할 때 제공됩니다
(
std::ranges::view_interface<D>
의 public 멤버 함수)
|
|
파생 뷰의 마지막 요소를 반환합니다.
bidirectional_range
와
common_range
를 만족할 때만 제공됩니다
(
std::ranges::view_interface<D>
의 public 멤버 함수)
|
|
파생 뷰의
n
번째 요소를 반환합니다.
random_access_range
를 만족할 때만 제공됩니다
(
std::ranges::view_interface<D>
의 public 멤버 함수)
|
|
추론 가이드
중첩 클래스
|
(C++23)
|
반복자 타입
( 설명 전용 멤버 클래스 템플릿* ) |
|
(C++23)
|
slide_view
가
common_range
가 아닐 때 사용되는 센티넬 타입
( 설명 전용 멤버 클래스 템플릿* ) |
헬퍼 템플릿
|
template
<
class
V
>
constexpr
bool
ranges::
enable_borrowed_range
<
slide_view
<
V
>>
=
|
(C++23부터) | |
ranges::enable_borrowed_range
의 이 특수화는 기본 뷰가 이를 만족할 때
slide_view
가
borrowed_range
를 만족하도록 합니다.
참고 사항
ranges::adjacent_view 와 ranges::slide_view 사이에는 유사점이 있습니다:
-
둘 다 크기가
N인 "슬라이딩 윈도우"를 생성합니다. -
둘 다 동일한 크기
S - N + 1을 가지며, 여기서S는S >= N > 0을 만족하는 적응된view의 크기입니다.
다음 표는 이러한 어댑터 간의 차이점을 보여줍니다:
| 뷰 어댑터 |
value_type
|
윈도우 크기
N
|
|---|---|---|
| ranges:: adjacent_view | std::tuple | 템플릿 매개변수 |
| ranges :: slide_view | ranges:: range | 런타임 인수 |
| 기능 테스트 매크로 | 값 | 표준 | 기능 |
|---|---|---|---|
__cpp_lib_ranges_slide
|
202202L
|
(C++23) |
std::ranges::slide_view
|
예제
#include <algorithm> #include <initializer_list> #include <iostream> #include <ranges> auto print_subrange = [](std::ranges::viewable_range auto&& r) { std::cout << '['; for (char space[]{0,0}; auto elem : r) std::cout << space << elem, *space = ' '; std::cout << "] "; }; int main() { const auto v = {1, 2, 3, 4, 5, 6}; std::cout << "All sliding windows of width:\n"; for (const unsigned width : std::views::iota(1U, 1U + v.size())) { auto const windows = v | std::views::slide(width); std::cout << "W = " << width << ": "; std::ranges::for_each(windows, print_subrange); std::cout << '\n'; } }
출력:
All sliding windows of width W: W = 1: [1] [2] [3] [4] [5] [6] W = 2: [1 2] [2 3] [3 4] [4 5] [5 6] W = 3: [1 2 3] [2 3 4] [3 4 5] [4 5 6] W = 4: [1 2 3 4] [2 3 4 5] [3 4 5 6] W = 5: [1 2 3 4 5] [2 3 4 5 6] W = 6: [1 2 3 4 5 6]
참조문헌
- C++23 표준 (ISO/IEC 14882:2024):
-
- 26.7.29 슬라이드 뷰 [range.slide]
참고 항목
적응된 뷰의 인접한 요소들에 대한 참조의 튜플로 구성된
view
(클래스 템플릿) (범위 어댑터 객체) |
|
|
(C++23)
|
다른
view
의 요소들을
N
크기의 겹치지 않는 연속적인 청크로 나타낸
view
s
의 범위
(클래스 템플릿) (범위 어댑터 객체) |