Namespaces
Variants

std:: end, std:: cend

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)
end cend
(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 end ( C & c ) - > decltype ( c. end ( ) ) ;
(1) (C++11부터)
(C++17부터 constexpr)
template < class C >
auto end ( const C & c ) - > decltype ( c. end ( ) ) ;
(2) (C++11부터)
(C++17부터 constexpr)
template < class T, std:: size_t N >
T * end ( T ( & array ) [ N ] ) ;
(3) (C++11부터)
(C++14부터 noexcept)
(C++14부터 constexpr)
template < class C >

constexpr auto cend ( const C & c ) noexcept ( /* see below */ )

- > decltype ( std :: end ( c ) ) ;
(4) (C++14부터)

주어진 범위의 끝(즉, 마지막 요소 다음의 요소)에 대한 반복자를 반환합니다.

1,2) c. end ( ) 를 반환합니다. 이는 일반적으로 c 가 나타내는 시퀀스의 끝 바로 다음을 가리키는 반복자입니다.
1) 만약 C 가 표준 Container 라면, C::iterator 객체를 반환합니다.
2) 만약 C 가 표준 Container 라면, C::const_iterator 객체를 반환합니다.
3) 배열의 끝을 가리키는 포인터를 반환합니다.
4) 반환값 std :: end ( c ) , c 는 항상 const-qualified로 처리됩니다.
만약 C 가 표준 Container 라면, C::const_iterator 객체를 반환합니다.

range-begin-end.svg

목차

매개변수

c - end 멤버 함수를 가진 컨테이너 또는 뷰
array - 임의 타입의 배열

반환값

1,2) c. end ( )
3) array + N
4) c. end ( )

예외

4)
noexcept 명세:
noexcept ( noexcept ( std :: end ( c ) ) )

오버로드

적합한 end() 멤버 함수를 노출하지 않지만 반복 가능한 클래스 및 열거형에 대해 end 의 사용자 정의 오버로드를 제공할 수 있습니다. 다음 오버로드들은 표준 라이브러리에서 이미 제공됩니다:

전문화 std::end
(함수 템플릿)
전문화 std::end
(함수 템플릿)
범위 기반 for 루프 지원
(함수)
범위 기반 for 루프 지원
(함수)

swap 의 사용과 유사하게(이는 Swappable 에서 설명됨), 일반적인 컨텍스트에서 end 함수의 전형적인 사용은 using std :: end ; end ( arg ) ; 와 동등하며, 이를 통해 사용자 정의 타입에 대한 ADL 에 의해 선택된 오버로드와 표준 라이브러리 함수 템플릿이 동일한 오버로드 집합에 나타날 수 있게 합니다.

template<typename Container, typename Function>
void for_each(Container&& cont, Function f)
{
    using std::begin;
    auto it = begin(cont);
    using std::end;
    auto end_it = end(cont);
    for (; it != end_it; ++it)
        f(*it);
}

인수 의존적 탐색 으로 발견된 end 의 오버로드는 std::ranges::end , std::ranges::cend std::ranges::end 에 의존하는 다른 사용자 지정 포인터 객체들의 동작을 사용자 정의하는 데 사용될 수 있습니다.

(C++20부터)

참고 사항

비 배열 오버로드들은 C :: end ( ) 의 동작을 정확히 반영합니다. 멤버 함수가 합리적인 구현을 가지고 있지 않은 경우 그 효과는 놀라울 수 있습니다.

std::cend 는 멤버 및 비멤버 범위 접근의 통합을 위해 도입되었습니다. 참고: LWG issue 2128 .

만약 C 가 얕은 const 뷰인 경우, std::cend 는 변경 가능한 반복자를 반환할 수 있습니다. 이러한 동작은 일부 사용자에게 예상치 못한 것입니다. 참고 자료: P2276 P2278 .

예제

#include <algorithm>
#include <iostream>
#include <vector>
int main()
{
    std::vector<int> v = {3, 1, 4};
    if (std::find(std::begin(v), std::end(v), 5) != std::end(v))
        std::cout << "Found a 5 in vector v!\n";
    int w[] = {5, 10, 15};
    if (std::find(std::begin(w), std::end(w), 5) != std::end(w))
        std::cout << "Found a 5 in array w!\n";
}

출력:

Found a 5 in array w!

참고 항목

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